欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來(lái)到入門(mén)教程網(wǎng)!

C語(yǔ)言

當(dāng)前位置:主頁(yè) > 軟件編程 > C語(yǔ)言 >

C/C++ 雙鏈表之逆序的實(shí)例詳解

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C語(yǔ)言|點(diǎn)擊: 次

C/C++ 雙鏈表之逆序的實(shí)例詳解

一、結(jié)點(diǎn)結(jié)構(gòu)

        雙向鏈表的數(shù)據(jù)結(jié)構(gòu)定義如下:      

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

        其中,ElemType可以是任意數(shù)據(jù)類(lèi)型如int、float或者char等,在算法中,規(guī)定其默認(rèn)為int類(lèi)型。

二、帶頭結(jié)點(diǎn)

        本文描述的是雙向鏈表逆序,鏈表逆序需要維護(hù)3個(gè)指針,分別指向前一個(gè)節(jié)點(diǎn)、當(dāng)前節(jié)點(diǎn)和下一個(gè)節(jié)點(diǎn),具體代碼如下:

 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;      // 保存當(dāng)前結(jié)點(diǎn)的下一結(jié)點(diǎn)
        p2->next = p1;      // 改變當(dāng)前結(jié)點(diǎn)的next域,指向它的前一個(gè)結(jié)點(diǎn)
        p1->prior = p2;     // 改變前一個(gè)結(jié)點(diǎn)的prior域,指向它的后一個(gè)結(jié)點(diǎn)
        p1 = p2;         // 指針移到下一個(gè)結(jié)點(diǎn)
        p2 = p3;
      }
      head->next = p1;       // 恢復(fù)頭結(jié)點(diǎn)
      p1->prior = head;
      return head;
    }

        在鏈表逆序過(guò)程中,非常重要的一點(diǎn)是要防止斷鏈問(wèn)題,因此,在移動(dòng)指針逆序某個(gè)結(jié)點(diǎn)時(shí),需要用一個(gè)指針指向該結(jié)點(diǎn)的下一結(jié)點(diǎn),防止下一結(jié)點(diǎn)丟失。

三、不帶頭結(jié)點(diǎn)

 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;
    }

        不帶頭結(jié)點(diǎn)的鏈表逆序與帶頭結(jié)點(diǎn)的區(qū)別在于紅色部分代碼,即初始p1指向的是第一個(gè)結(jié)點(diǎn)而不是頭結(jié)點(diǎn),最后head直接指向p1而不是用其next來(lái)指向p1。

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

上一篇:深入理解c++模板中的class與typename

欄    目:C語(yǔ)言

下一篇:C語(yǔ)言變量類(lèi)型的深入分析

本文標(biāo)題:C/C++ 雙鏈表之逆序的實(shí)例詳解

本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1378.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有