欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

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

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

創(chuàng)新互聯(lián)公司公司2013年成立,是專(zhuān)業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元福山做網(wǎng)站,已為上家服務(wù),為福山各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話(huà):18980820575

一、結(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/C++雙鏈表之逆序的實(shí)例詳解
當(dāng)前鏈接:http://aaarwkj.com/article14/jesjde.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、靜態(tài)網(wǎng)站商城網(wǎng)站、品牌網(wǎng)站制作網(wǎng)站制作、App開(kāi)發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
久久男女激情免费视频| 91亚洲精品一区二区三区| 日韩精品一二三黄色一级| 国产中文字幕精品在线| 色哟哟亚洲精品一区二区| 久久草福利视频在线观看| 亚洲日本国产精品第一页| 中字幕人妻一区二区三区| 麻豆剧传媒国产精选av| 草莓午夜视频在线观看| 国产极品美女高潮抽搐| 一本色桃子精品久久中文字幕 | 国产精品区一区二区三区| 开心五月婷婷丁香综合| 在线观看精品日本一区二| 91亚洲精品综合久久| 免费日本高清色噜噜视频| 在线观看一区二区三区国产视频 | 日本a亚洲中文字幕永远| 国产精品一区二区三区 在线| 亚洲国产精品一区二区三| 精品国产免费第一区二区三| 日韩欧美国产精品一区二区| 日韩精品中文字幕有码| 午夜福利精品在线观看| 亚洲国际天堂av在线| 欧亚日韩精品一区二区在线| 国产日韩手机在线不卡视频| 亚洲一区有码在线观看| 中文字幕人成乱码在线| 熟女另类视频在线观看| 亚洲一区二区在线视频在线观看| 精品人妻中文字幕在线| 亚洲国产日韩精品欧美| 欧美熟妇精品一级视频| 九九99九九99九九精品在线观看| 亚洲永久免费黄色av| 日本在线观看高清区一区二| 中国亚洲视频一区二区| 粉嫩av蜜臀一区二区三区| 国产在线拍揄自揄视频不卡99|