文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言如何实现双向链表和双向循环链表

2023-06-16 21:09

关注

本文小编为大家详细介绍“C语言如何实现双向链表和双向循环链表”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言如何实现双向链表和双向循环链表”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

双向链表和双向循环链表

和单向链表相比,多了一个前驱结点。如果他为空,那么next和prior都指向自己。而对于双循环链表,只需要最后一个元素的next指向head->next,head->next的prior指向最后一个节点即可。

插入操作

新节点s插入链表,s->next给p结点,s->prior给p->prior,然后,p->prior->next指向s,p->prior再指向s。顺序需要注意

s->next = p;s->prior = p->prior;p->prior->next = s;p->prior = s;

删除操作

删除结点p。p->next->prior 指向 p->prior,p->prior->next 指向 p->next 。最后将p结点delete。

p->prior->next = p->next;p->next->prior = p->prior;delete p;

实例操作

(附截图)

C语言如何实现双向链表和双向循环链表

注意:因为函数没有返回Node*类型,所以这里对指针进行引用,否则在退出函数的时候,并没有保存改变。如果需要删除全部链表,需要保存InitList之后的head地址,否则会遗漏一个Node结点没有删除。

代码实现:

#include<iostream>#include<cstddef>#include<cstdio>using namespace std;const int OK = 1;const int ERROR = 0;const int LETTERNUM = 26;typedef char ElemType;struct Node{  ElemType data;  Node * prior;//前驱结点  Node * next;//后驱结点 };int InitList(Node *&L){  Node *p,*q;  int i;    L = new Node; //头结点   L->next = L->prior = NULL;  p = L; //p是当前指针     for(int i=0;i<LETTERNUM;i++){    q = new Node; //q是临时指针     q->data = 'A' + i;    q->prior = p;    q->next = p->next;    p->next = q;    p = q;//指针移动   }  p->next = L->next; //尾结点指向head->next(第一个有字母的地址)   L->next->prior = p;    return OK;}void Change(Node *&L,int i){ //移动头指针   if (i>0){    while(i--){      L = L->next;    }  }  else if (i<0){    L = L->next ;     while(i++){      L = L->prior;    }  }  else{    L = L->next;  }}int main(){  Node *head = NULL;  int i,n;  InitList(head);  //Node *s_head = head; // 保存头结点之后删除   cout<<"输入位置:"<<endl;  cin>>n;  Change(head,n);    for(i = 0;i<LETTERNUM;++i){    head = head->next;    cout<<head->data<<" ";   }    cout<<endl;  return 0;}

读到这里,这篇“C语言如何实现双向链表和双向循环链表”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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