当前位置: 首页 > news >正文

中国临海建设规划局网站wordpress 4.8.2 中文

中国临海建设规划局网站,wordpress 4.8.2 中文,centos网站开发,小城镇建设期刊网站前言 数据结构入门 — 双向链表详解* 博客主页链接:https://blog.csdn.net/m0_74014525 关注博主,后期持续更新系列文章 文章末尾有源码 *****感谢观看,希望对你有所帮助***** 系列文章 第一篇:数据结构入门 — 链表详解_单链表…

前言

数据结构入门 — 双向链表详解*
博客主页链接:https://blog.csdn.net/m0_74014525
关注博主,后期持续更新系列文章
文章末尾有源码
*****感谢观看,希望对你有所帮助*****


系列文章

第一篇:数据结构入门 — 链表详解_单链表
第二篇:数据结构入门 — 链表详解_双向链表
第三篇:数据结构入门 — 链表详解_循环链表


文章目录

  • 前言
  • 系列文章
  • 什么是双向链表
  • 概念与结构(图文)
  • 双向链表与单链表的区别
  • 带头双向循环链表接口实现(代码演示)
    • 1. 动态存储结构
    • 双向链表打印
    • 增删查改接口
    • 双向链表销毁
  • 五、所有文件代码
    • 1. Gitee链接
  • 总结


什么是双向链表

双向链表(Doubly Linked List)是一种链表数据结构,它的每个节点都含有两个指针,一个指向前一个节点,一个指向后一个节点。相比较于单向链表,双向链表可以双向遍历,即可以从头到尾或从尾到头遍历链表。在双向链表中,每个节点包含两个指针域和一个数据域。其中,一个指针指向前驱节点,另一个指针指向后继节点。这两个指针使得双向链表的插入、删除等操作不需要像单向链表那样需要遍历整个链表来寻找前驱节点,提高了链表的操作效率。

概念与结构(图文)

在这里插入图片描述
带头双向循环链表:结构最复杂,一般用在单独存储数据。实际中使用的链表数据结构,都是带头双向循环链表。另外这个结构虽然结构复杂,但是使用代码实现以后会发现结构会带来很多优势,实现反而简单了,后面我们代码实现了就知道了。

双向链表与单链表的区别

双向链表和单链表是两种不同的链表结构。

单向链表是一种链表,在每个节点中包含指向下一个节点的指针。这意味着在单向链表中,节点只能从头开始遍历到尾部。在单向链表中,每个节点只存储指向下一个节点的指针,而不存储指向前一个节点的指针。

双向链表是一种链表,在每个节点中包含指向下一个节点和前一个节点的指针。这意味着在双向链表中,节点可以被从头到尾或从尾到头遍历。在双向链表中,每个节点存储指向前一个节点和下一个节点的指针。

因此,双向链表可以更方便地进行双向遍历,但是需要更多的内存空间来存储每个节点的两个指针。相比之下,在单向链表中,只需要一个指针来指向下一个节点,因此内存占用量更小。

带头双向循环链表接口实现(代码演示)

带头+双向+循环链表增删查改实现

1. 动态存储结构

typedef int STDataType;
typedef struct ListNode
{struct ListNode* prev;struct ListNode* next;STDataType data;
}LTNode;

双向链表打印

void LTPrint(LTNode* phead)
{assert(phead);printf("phead<->");//跳过哨兵位LTNode* cur = phead->next;while (cur != phead){printf("%d<->", cur->data);cur = cur->next;}printf("\n");
}

增删查改接口

根据增删查改顺序编排
双向链表头插:

//头插
void  LTPushFront(LTNode* phead, STDataType x)
{assert(phead);LTNode* newnode = BuyLTNode(x);LTNode* first = phead->next;newnode->next = first;first->prev = newnode;phead->next = newnode;newnode->prev = phead;}

双向链表尾插:

//尾插
void LTPushBack(LTNode* phead, STDataType x)
{assert(phead);LTNode* newnode = BuyLTNode(x);//找到最后一个LTNode* tail = phead->prev;newnode->prev = tail;tail->next = newnode;newnode->next = phead;phead->prev = newnode;
}

双向链表头删:

//头删
void LTPopFront(LTNode* phead)
{assert(phead);assert(phead->next != phead);LTNode* first = phead->next;LTNode* second = first->next;free(first);phead->next = second;second->prev = phead;}

双向链表尾删:

//尾删
void LTPopBack(LTNode* phead)
{assert(phead);assert(phead->next != phead);LTNode* tail = phead->prev;LTNode* tailprev = tail->prev;free(tail);phead->prev = tailprev;tailprev->next = phead;}

查找:

LTNode* LTFind(LTNode* phead, STDataType x)
{assert(phead);LTNode* cur = phead->next;while (cur != phead){if (cur->data == x){return cur;}cur = cur->next;}return NULL;
}

在指点位置插入:

void LTInsert(LTNode* pos, STDataType x)
{LTNode* newnode = BuyLTNode(x);LTNode* posprev = pos->prev;newnode->next = pos;pos->prev = newnode;posprev->next = newnode;newnode->prev = posprev;}

在指点位置删除:

// 把pos删除
void LTErase(LTNode* pos)
{LTNode* posprev = pos->prev;LTNode* posnext = pos->next;free(pos);posprev->next = posnext;posnext->prev = posprev;
}

双向链表销毁

void LTDestory(LTNode* phead)
{LTNode* cur = phead->next;while (cur != phead){LTNode* next = cur->next;free(cur);cur = next;}free(phead);phead = NULL;
}

五、所有文件代码

1. Gitee链接

***查看所有代码***
点击右边蓝色文字 DuckBro Gitee 代码仓库


总结

带头双向循环链表的基本概念和常见操作。带头双向循环链表是一种特殊的双向链表,它多了一个头节点和一个尾节点,并且首尾相连形成一个环。

这样可以实现循环遍历链表。在带头双向循环链表中,插入、删除节点等操作都有特殊处理方式。带头双向循环链表在实际应用中比较常见,如操作系统中的进程管理、音乐播放器中的播放列表等。


如这篇博客对大家有帮助的话,希望 三连 支持一下 !!! 如果有错误感谢大佬的斧正 如有 其他见解发到评论区,一起学习 一起进步。

http://www.yayakq.cn/news/659932/

相关文章:

  • 手机网站制作大约多少钱招商网站
  • 当当网网站建设方案机械网站建设中心
  • 大型门户网站源码有什么网站用名字做图片大全
  • 网站建设开发服务费下什么科目盘锦网站建设价格
  • seo站长博客网站建设哪家效果好
  • 网页美工设计总结一键优化清理
  • 作风建设方面的网站视频剪辑制作
  • 宿迁哪里有做网站开发的无锡网络营销推广公司
  • 网站开发公司业务员培训泰安可以做网站的公司
  • wordpress打开文章深圳网站搜索优化
  • 网站备案怎么取消网页游戏排行榜单传奇
  • 国内外c2c网站有哪些主流网站开发工具
  • 网站二级域名建站属于子站吗山东网站建设哪家权威
  • 关于网站建设项目收取费用做网站好还是小程序好
  • 集宁网站建设SEO优化宜兴市建设局网站
  • 国内专门做酒的网站有哪些做网站需要会什么
  • 合肥网站制作公司排名南宁网站快速优
  • 网站推广的方式村建站是什么部门
  • 网站网络优化服务器项目四网站建设内容
  • 考证培训机构报名网站wordpress文章幻灯片
  • 制作网站的原因公司网站建设申请书
  • 广东省建设工程执业中心网站页面设计感想
  • 广东省建设业协会网站网站 备案 查询
  • 简洁汽车配件网站模板章丘做网站
  • 网站如何做微信推广有人做彩票网站吗
  • 威海网站建设 孔企业网站制作开发
  • 答建设网站哪里有做彩票网站了
  • 网站建设需要的一些技术中企动力的网站开发语言
  • 成都网络公司网站网站本科
  • 旅游网站开发分析报告高明网站设计