链表--part 1--链表基础理论(概括)

文章目录

    • 单链表
    • 双链表
    • 循环链表
    • 链表
      • 链表的定义
      • 删除节点
      • 增加节点

首先什么是链表,链表是一种通过指针串联在一起的线性结构,每一个节点由两部分组成,一个是数据域一个是指针域(存放指向下一个节点的指针),最后一个节点的指针域指向null(空指针的意思)。

链表的入口节点称为链表的头结点也就是head。

链表--part 1--链表基础理论(概括)_第1张图片
链表的数据域分为两个区域: 一个是数据域,一个是地址域。

下面是链表的分类

单链表

单链表实际上就是上面的那一个图。见上图即可。

双链表

单链表中的指针域只能指向节点的下一个节点。

双链表:每一个节点有两个指针域,一个指向下一个节点,一个指向上一个节点。

双链表 既可以向前查询也可以向后查询。

链表--part 1--链表基础理论(概括)_第2张图片

循环链表

循环链表,顾名思义,就是链表首尾相连。

循环链表可以用来解决约瑟夫环问题

链表--part 1--链表基础理论(概括)_第3张图片

链表

由于数组的内存在空间上是连续存储的,所以对于数组的删除节点只需要直接进行【】进行覆盖即可。

但是链表在内存中可不是连续分布的。链表是通过指针域的指针链接在内存中各个节点。

所以链表中的节点在内存中不是连续分布的,而是散乱分布在内存中的某地址上,分配机制取决于操作系统的内存管理。

链表的定义

struct ListNode
{
	int val;//数据域
	ListNode* next;//地址域
	ListNode(int x): val(x),next(NULL){}//构造函数
};

链表的调用:

ListNode* p = new ListNode(5);
cout << p->val << endl;
ListNode* q = new ListNode();//跟编译器相关,有的可以有的不行,有的编译器可以自动帮你定义一个新的,有的只有在没有的情况下帮你定义。
cout << q->val << endl;

删除节点

其实图片已经展示的很清楚了,实际上按照图片的操作来即可,数据结构就是按照自己的图示来进行的操作。

链表--part 1--链表基础理论(概括)_第4张图片

增加节点

同理

链表--part 1--链表基础理论(概括)_第5张图片

你可能感兴趣的:(算法/leetcode/洛谷,链表,数据结构)