一、链表的种类:
1、单链表
链表是一种通过指针串联在一起的线性结构,每一个节点由两部分组成,一个是数据域一个是指针域(存放指向下一个节点的指针),最后一个节点的指针域指向null(空指针的意思)。
链表的入口节点称为链表的头结点也就是head。
2、双链表
单链表中的指针域只能指向节点的下一个节点。
双链表:每一个节点有两个指针域,一个指向下一个节点,一个指向上一个节点。
双链表 既可以向前查询也可以向后查询。
3、循环链表
循环链表,顾名思义,就是链表首尾相连。
二、链表的存储方式
数组是在内存中是连续分布的,但是链表在内存中可不是连续分布的。链表中的节点(两部分)在内存中不是连续分布的 ,而是散乱分布在内存中的某地址上,分配机制取决于操作系统的内存管理。
三、链表的定义
public class ListNode {
int val;
ListNode next;
ListNode() {}
ListNode(int val) { this.val = val; }
ListNode(int val, ListNode next) { this.val = val; this.next = next; }
}
四、删除节点
删除D节点
只要将C节点的next指针 指向E节点。
C++里最好是再手动释放这个D节点,释放这块内存。
其他语言例如Java、Python,就有自己的内存回收机制,就不用自己手动释放了。
五、添加节点
链表的增添和删除都是O(1)操作,也不会影响到其他节点。但是,要是删除第五个节点,需要从头节点查找到第四个节点通过next指针进行删除操作,查找的时间复杂度是O(n)。
六、与数组做性能对比
插入/删除(时间复杂度) | 查询(时间复杂度) | 场景 | |
数组 | o(n) | o(1) | 查询多 |
链表 | o(1) | o(n) | 增删多 |