文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C++双向链表的增删查改操作方法源码分析

2023-07-05 16:07

关注

这篇“C++双向链表的增删查改操作方法源码分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++双向链表的增删查改操作方法源码分析”文章吧。

一、什么是双链表

双向链表也叫双链表,是链表的一种,它是单链表的升级版,与单链表不同的是,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。而单链表只有一个指针,指向后继。

双链表示意图

C++双向链表的增删查改操作方法源码分析

首先创立一个结构体,其中包含一个prev指针,一个val值以及一个next指针。如图可以看出其中prev指针指向的是上一个结构体,而next指针指向的是下一个结构体。结构体代码

typedef int LTDataType;typedef struct ListNode{LTDataType _data;struct ListNode* _next;struct ListNode* _prev;}ListNode;

二、双链表功能函数

1、创建返回链表的头结点

ListNode* ListCreate(){ListNode* guard = (ListNode*)malloc(sizeof(ListNode));if (guard == NULL){perror("ListCreate");exit(-1);}guard->_next = guard;guard->_prev = guard;return guard;}

2、双向链表打印

void ListPrint(ListNode* pHead){assert(pHead);ListNode* cur = pHead;while (cur->_next != pHead){cur = cur->_next;printf("%d->", cur->_data);}printf("NULL\n");return;}

3、双向链表尾插

void ListPushBack(ListNode* pHead, LTDataType x){ListNode* newnode = (ListNode*)malloc(sizeof(ListNode));if (newnode == NULL){perror("ListPushBack");exit(-1);}newnode->_data = x;ListNode* cur = pHead->_prev;newnode->_next = pHead;newnode->_prev = cur;cur->_next = newnode;pHead->_prev = newnode;return;}

4、双向链表尾删

void ListPopBack(ListNode* pHead){assert(pHead);ListNode* pre = pHead->_prev->_prev;free(pHead->_prev);pre->_next = pHead;pHead->_prev = pre;return;}

5、双向链表头插

void ListPushFront(ListNode* pHead, LTDataType x){assert(pHead);ListNode* newnode = (ListNode*)malloc(sizeof(ListNode));if (newnode == NULL){perror("ListPushFront");exit(-1);}newnode->_data = x;newnode->_next = pHead->_next;newnode->_prev = pHead;pHead->_next = newnode;newnode->_next->_prev = newnode;return;}

6、双向链表头删

void ListPopFront(ListNode* pHead){assert(pHead);ListNode* cur = pHead->_next->_next;free(pHead->_next);pHead->_next = cur;cur->_prev = pHead;return;}

7、双向链表查找

ListNode* ListFind(ListNode* pHead, LTDataType x){assert(pHead);ListNode* cur = pHead;while (cur->_next != pHead){cur = cur->_next;if (cur->_data == x)return cur;}printf("Can't find.\n");return NULL;}

8、双向链表在pos的前面进行插入

void ListInsert(ListNode* pos, LTDataType x){assert(pos);ListNode* newnode = (ListNode*)malloc(sizeof(ListNode));if (newnode == NULL){perror("ListPushFront");exit(-1);}ListNode* cur = pos->_prev;newnode->_next = pos;newnode->_prev = cur;pos->_prev = newnode;cur->_next = newnode;return;}

9、双向链表删除pos位置的节点

void ListErase(ListNode* pos){ListNode* front = pos->_prev;ListNode* behind = pos->_next;free(pos);front->_next = behind;behind->_prev = front;return;}

10、双向链表销毁

void ListDestory(ListNode* pHead){assert(pHead);while (pHead->_next != pHead){pHead->_next = pHead->_next->_next;free(pHead->_next->_prev);pHead->_next->_prev = pHead;}return;}

以上就是关于“C++双向链表的增删查改操作方法源码分析”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯