1、列表
包括
(1)数组
【1】会在内存中开辟一个连续的内存空间
【2】随机访问的效率比链表高。数组只要给定下标,则可以直接定位到该下标所对应的元素,而链表每次都是从头节点开始遍历。
【3】对元素的增删操作的效率比链表低。这里说的是从数组的中间插入或删除一个元素,并且数组中元素很多,实验证明,在数组头部或结尾增加或删除一个元素的效率和链表差不多。
为什么?
比如,每次对数组中间某一个元素进行删除的操作,则此元素后面的所有元素都得往前面移动,耗费大量的时间和性能。
而对链表中间某一个元素进行删除的操作,只需将此节点的指针与前驱结点和后继节点断开即可,元素并没有发生移动。
这个特点,可以解释ArrayList与LinkedList之间的区别
(2)链表
【1】通过一个个指针将节点串起来
【2】对于元素的随机访问,需要使用计数器来访问指定的元素,并且只能从头节点开始访问,每访问一个节点,计数器加1,直到给定的“下标”,此操作很耗时,时间复杂度为O(N)
【3】增加元素和删除元素的效率很高
(3)队列
【1】不支持随机访问
【2】先进先出
【3】线程池中的线程就是从任务队列中取出任务
(4)栈
【1】不支持随机访问
【2】后进先出
2、树
(1)二叉树
【1】每个节点最多只有两个子节点
(