欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

C/C++ 双链表之逆序的实例详解

时间:2020-11-04 10:57:55|栏目:C代码|点击:

C/C++ 双链表之逆序的实例详解

一、结点结构

        双向链表的数据结构定义如下:      

 typedef struct node
    {
      ElemType data;
      struct node *prior
      struct node *next;
    }list;

        其中,ElemType可以是任意数据类型如int、float或者char等,在算法中,规定其默认为int类型。

二、带头结点

        本文描述的是双向链表逆序,链表逆序需要维护3个指针,分别指向前一个节点、当前节点和下一个节点,具体代码如下:

 list *reverselist(list *head)
    {
      if ((NULL == head) || (NULL == head->next))
      {
        return head;
      }
      list *p1=head->next, *p2=p1->next, *p3=NULL;
      p1->next = NULL;
      while (p2)
      {
        p3 = p2->next;      // 保存当前结点的下一结点
        p2->next = p1;      // 改变当前结点的next域,指向它的前一个结点
        p1->prior = p2;     // 改变前一个结点的prior域,指向它的后一个结点
        p1 = p2;         // 指针移到下一个结点
        p2 = p3;
      }
      head->next = p1;       // 恢复头结点
      p1->prior = head;
      return head;
    }

        在链表逆序过程中,非常重要的一点是要防止断链问题,因此,在移动指针逆序某个结点时,需要用一个指针指向该结点的下一结点,防止下一结点丢失。

三、不带头结点

 list *reverselist(list *head)
    {
      if ((NULL == head) || (NULL == head->next))
      {
        return head;
      }
      list *p1=head, *p2=p1->next, *p3=NULL;
      p1->next = NULL;
      while (p2)
      {
        p3 = p2->next;
        p2->next = p1;
        p1->prior = p2;
        p1 = p2;
        p2 = p3;
      }
      head = p1;
      return head;
    }

        不带头结点的链表逆序与带头结点的区别在于红色部分代码,即初始p1指向的是第一个结点而不是头结点,最后head直接指向p1而不是用其next来指向p1。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

上一篇:详解C++循环创建多级目录及判断目录是否存在的方法

栏    目:C代码

下一篇:C语言正则表达式操作示例

本文标题:C/C++ 双链表之逆序的实例详解

本文地址:http://www.codeinn.net/misctech/18913.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有