【算法基础】数据结构| 单链表+双链表 代码实现+图解+原理

这篇具有很好参考价值的文章主要介绍了【算法基础】数据结构| 单链表+双链表 代码实现+图解+原理。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

分别建立两个有3个元素结点的单链表(无头结点),然后对两个链表进行各自排序(显示,算法,算法,数据结构,java,c++,链表

  • 博主简介:努力学习的预备程序媛一枚~
  • 博主主页: @是瑶瑶子啦
  • 所属专栏: Java岛冒险记【从小白到大佬之路】

前言

因为瑶瑶子正在备战蓝桥杯和校内ACM选拔赛,最近在学习算法相关的知识。我是借助AcWing网站来学习的,这篇文章是我学习就我学习内容的一个笔记,其中的一些对原理的解释是我学习过程中可能看到弹幕或者评论的小伙伴,觉得讲的很有道理醍醐灌顶,就引用过来了。
这篇是关于数据结构,主要是利用数组模拟各种数据结构,主要是提高算法效率。
对于一些比较晦涩难懂\让人头秃的地方,我习惯采用画图的方式来理解,所以你将看到我基于算法模板或题目精心绘制的图解,希望能帮助一起学算法的同学噢!
因为瑶瑶子目前还是小菜鸡,可能会有理解不到位的地方,或者可以理解得更好的地方,还请大家多多指出哦!❤

注意!下面每一种数据结构的讲解方式,采用代码模板+文字说明&解释+图解

1.单链表(邻接表)

作用:多用于邻接表,存储

代码模板

// head存储链表头,e[]存储节点的值,ne[]存储节点的next指针,idx表示当前用到了哪个节点,后一个
int head, e[N], ne[N], idx;
//NULL相当于-1,所以head = -1相当于head=NULL
// 初始化
void init()
{
    head = -1;
    idx = 0;
}

// 在链表头插入一个数a
void insert(int a)
{   
    e[idx] = a, ne[idx] = head, head = idx ++ ;
}
//将x插入到下标是k的点之后
void insert(int k, int x)
{
	e[idx] = x;
	ne[idx] = ne[k]
	ne[k] = idx;
	idx ++;
}

// 将头结点删除,需要保证头结点存在
void remove()
{
    head = ne[head];
}
  • 存储节点数组的e[N]和存储该节点的next指针数组ne[N]通过下标关联
  • idx只是记录当前的操作的位置,一般实现的链表idx是乱序的(前后的节点的数组下标不需要连续,需要通过当前的ne[i]找到下一个idx。这也是两者的联系
  • head一开始=-1,这个-1相当于物理地址的NULL,表示链表为空,即head指向一个头节点,而使用头插法,又巧妙的使这个空节点成为尾节点。联想结构体实现的单链表,最后一个节点的指针域是NULL所以,数组实现单链表的最后一个节点,假设是i,那么ne[i]=-1
  • 这里模拟的是没有头节点,head指针直接指向首元节点的单链表
  • 虽然数组模拟的链表没有用结构体/类模拟的好理解,但是本质都是一样的,我们可以类比一下,对于一个节点Node。
  • 所以其实画图的时候,也没必要分的那么清楚,其实在我学习数组模拟链表之前,我一直认为数组&链表属于物理结构,现在才发现,其实链表是一种逻辑结构!
比较点 结构体/类模拟Node 数组模拟Node
节点本身指针 物理地址,node 通过在数组下标,表示自身指针
数值域 就在结构体中定义node.val val[node],通过数组来存储数值域
指针域 结构体中定义,node. next next[node],通过数组来存储

图解
分别建立两个有3个元素结点的单链表(无头结点),然后对两个链表进行各自排序(显示,算法,算法,数据结构,java,c++,链表
插入操作(头插法)
分别建立两个有3个元素结点的单链表(无头结点),然后对两个链表进行各自排序(显示,算法,算法,数据结构,java,c++,链表

2.双链表

学习了数组模拟单链表,其实双链表就很好理解了。其实就是多了一个指针域。

  • 单链表:ne[i]存储指针为i的节点的next指针
  • 双链表
    • l[i],指针为i的节点的前驱(指向前一个节点)
    • r[i],指针为i的节点的后驱(指向后一个节点)
//e[index],表示节点的值,l[index]表示节点的左指针,r[index]表示节点的右指针,idx表示当前用到哪个节点的”地址“

int e[N],l[N],r[N],idx;

//初始化
void init(){
  //0是左端点,1是右端点
  r[0] = 1,l[1] = 0;
  idx = 2;
}
//在节点a的右边插入一个数x
void insert(int a,int x){
  //1、让待插入节点占位
  e[idx] = x;
  //2、处理待插入点左右两侧
  l[idx] = a,r[idx] = r[a];//注意,这里必须是r[a],因为a的下一个节点不一定和a顺序存储
  //3、处理前一个节点和后一个节点
  l[r[a]] = idx,r[a] = idx++;
}

分别建立两个有3个元素结点的单链表(无头结点),然后对两个链表进行各自排序(显示,算法,算法,数据结构,java,c++,链表

分别建立两个有3个元素结点的单链表(无头结点),然后对两个链表进行各自排序(显示,算法,算法,数据结构,java,c++,链表
Java岛冒险记【从小白到大佬之路】

LeetCode每日一题–进击大厂文章来源地址https://www.toymoban.com/news/detail-790954.html

到了这里,关于【算法基础】数据结构| 单链表+双链表 代码实现+图解+原理的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构--线性表(顺序表、单链表、双链表、循环链表、静态链表)

    前言  学习所记录,如果能对你有帮助,那就泰裤辣。 目录 1.线性表概念 定义 基本操作 2.顺序表 定义 顺序表的实现--静态分配 动态分配 顺序表的特点 顺序表的插入和删除 顺序表的查找 按位查找  按值查找 3.单链表 定义 单链表的初始化 不带头节点的单链表 带头节点的单

    2024年02月11日
    浏览(63)
  • 【算法基础】(二)数据结构 --- 单链表

    ✨个人主页:bit me ✨当前专栏:算法基础 🔥专栏简介:该专栏主要更新一些基础算法题,有参加蓝桥杯等算法题竞赛或者正在刷题的铁汁们可以关注一下,互相监督打卡学习 🌹 🌹 🌹 实现一个单链表,链表初始为空,支持三种操作: 向链表头插入一个数; 删除第 k 个插

    2023年04月17日
    浏览(97)
  • 双链表——“数据结构与算法”

    各位CSDN的uu们你们好呀,今天,小雅兰又回来了,到了好久没有更新的数据结构与算法专栏,最近确实发现自己有很多不足,需要学习的内容也有很多,所以之后更新文章可能不会像之前那种一天一篇或者一天两篇啦,话不多说,下面,让我们进入双链表的世界吧  之前小雅

    2024年02月04日
    浏览(38)
  • 第一百零六天学习记录:数据结构与算法基础:单链表(王卓教学视频)

    结点在存储器中的位置是任意的,即逻辑上相邻的数据元素在物理上不一定相邻 线性表的链式表示又称为非顺序映像或链式映像。 用一组物理位置任意的存储单元来存放线性表的数据元素。 这组存储单元既可以是连续的,也可以是不连续的,甚至是零散分布在内存中的任意

    2024年02月16日
    浏览(55)
  • 【数据结构】数组、双链表代码实现

    💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢迎在文章下方留下你的评论和反馈。我期待着与你分享知识、互

    2024年02月19日
    浏览(45)
  • 【一起学数据结构与算法】Java实现双链表

    双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链表。 打印双链表非常简单,只需要单独创一个结点

    2024年02月22日
    浏览(42)
  • 单链表——“数据结构与算法”

    各位CSDN的uu们你们好呀,今天,小雅兰的内容终于是我们心心念念的单链表啦,这一块呢,是一个很重要的部分,也是一个对目前的我来说,比较困难的部分,下面,就让我们进入单链表的世界吧 之前小雅兰写过顺序表的内容: 顺序表(更新版)——“数据结构与算法”_认

    2023年04月26日
    浏览(44)
  • 【数据结构】单链表完整代码实现

    前置文章:顺序表的代码实现 每个结点除了存放数据元素外,还要存储指向下一个结点的指针。 不要求大片连续空间 改变容量方便 不可随机存取 要耗费一定空间存放指针 代码结构: 定义单链表结构 初始化单链表 单链表的取值方法 单链表的查找方法 单链表的插入方法 单

    2024年02月07日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包