91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-10-12 22:28:05 來源:腳本之家 閱讀:301 作者:lqh 欄目:編程語言

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。

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

奈曼旗| 保康县| 台北县| 织金县| 呼和浩特市| 灵石县| 阜宁县| 苏尼特右旗| 莱西市| 晋城| 图片| 慈利县| 神池县| 揭阳市| 新民市| 钦州市| 隆尧县| 江山市| 锦屏县| 镇安县| 本溪| 密山市| 寻乌县| 兰州市| 余江县| 谢通门县| 镶黄旗| 固镇县| 无棣县| 南召县| 修文县| 长顺县| 淮滨县| 赤峰市| 青河县| 宜章县| 余姚市| 天祝| 清苑县| 拉萨市| 色达县|