国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C/C++ 雙鏈表之逆序的實例詳解

2020-01-26 14:02:12
字體:
來源:轉載
供稿:網友

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。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 高台县| 江达县| 赤峰市| 宁蒗| 钟祥市| 丹巴县| 永康市| 宁波市| 周至县| 中卫市| 阜宁县| 敦煌市| 木里| 成武县| 专栏| 永安市| 繁昌县| 九江市| 习水县| 广平县| 名山县| 景东| 宁远县| 万年县| 土默特右旗| 贺州市| 乐平市| 元谋县| 靖安县| 博罗县| 长治县| 甘南县| 三亚市| 沭阳县| 淅川县| 临邑县| 合肥市| 随州市| 浮山县| 高唐县| 申扎县|