数据结构学习笔记

数组

数组是可以在内存中连续存储多个元素的结构,在内存中的分配也是连续的。

优点:1、按照索引查询元素速度快;2、按照索引便利数组方便。

缺点:1、数组大小固定后无法扩容;2、数组只能存储一种类型的数据;3、添加,删除的操作慢,因为要移动其他的元素。

栈是一种特殊的线性表,只能在线性表的一段操作(栈顶),栈底不允许操作。栈的特点是先进后出,更适用于递归方面的操作。

队列

队列与栈一样,也是一种线性表,不同的是队列是在一段添加元素,另一端取出元素,也就是先进先出。常用于多线程阻塞队列管理。

链表

链表是物理存储单元上非连续的,非顺序的存储结构,数据元素的逻辑顺序是通过链表的指针地址实现,每个元素包含两个结点,一个是存储元素的数据域,另一个是指向下一个结点地址的指针域。根据指针的指向,链表能形成不同的结构,如单链表,双向链表,循环链表等。双向链表就说由两个指针,一个指向前驱元素,一个指向后继元素。

优点:1、不需要初始化容量,可以任意加减空间;2、添加、删除元素很快;

缺点:1、含有大量指针,故占用空间大;2查找元素 需要遍历,非常耗时。

适用于数据量较小,但需要频发增加删除的场景。

树的每个结点有零个或多个子节点;

没有父节点的节点成为跟结点;

每一个非跟 节点有且只有一个父节点;

除了跟节点,每个子节点可以分为多个不相交的子树;

二叉树是一种特殊的树:1、每个结点最多有两颗子树,结点的度最大为2;2、左子树和右子树是有顺序的,次序不能颠倒;3、即使某个结点只有一个子树,也要区分左右子树。

二叉树添加、删除元素都很快,且在查找方面也存在很多优化算法。平衡二叉树,红黑树,B+树等都属于二叉树。

散列表

散列表也叫哈希表,是根据关键码和值(key和value)直接进行访问的数据结构。通过某种映射关系,将key转换成整型数字,再将该数字对数组长度取余,结果作为数组下标,将value存在该数字为下标的数组空间里。

堆是一种比较特殊的数据结构,可以被看做一颗树的数组对象。

1、堆中某个节点的值总时不大于或小于其父结点的值;2、堆总时一颗完全二叉树。

将根节点做大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或者小跟堆。

图是由结点有穷集合V和边E组成。其中为了域树形结构加以区别,在图结构中常常将结点称为顶点,边是顶点的有序偶对,若两个顶点之间存在一条边,则表示两个顶点具有相邻关系。按照顶点指向的方向可分为无向图和有向图。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值