数据结构
树形结构
有平衡树、不平衡树、二叉树、红黑树
链表
链表查询慢:链表中的地址不是连续的,每次查询元素,都必须从头开始查询
增删快:链表结构,增加/删除一个元素,对链表的整体结构没有影响,所以增删快
链表中的每一个元素也称之为一个节点,一个节点包含了一个数据源(存储数组),两个指针域(存储地址)
链表又分为单向链表和双向链表,
单向链表:链表中只有一条链子,不能保证元素的顺序(存储的元素和取出元素的顺序有可能不一致)
双向链表:链表中有两条链子,有一条是专门记录元素的顺序,是一个有序的集合
数组
查询快:数组的地址是连续的,我们通过数组的首地址可以找到数组,通过数组的索引可以快速查找某一个元素
增删慢:数组的长度是固定的,我们想要增加/删除一个元素,必须创建一个新数组,把原数组的数据复制过来
栈
因为进口和出口在同一侧,先进去的就在最下面,后进去的在上面,所以先进后出
队列
入口和出口不在同一侧,因此先进去的先出来。即先进先出
队列
入口和出口不在同一侧,因此先进去的先出来。即先进先出