• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天之道

            享受編程的樂趣。
            posts - 118, comments - 7, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
            #include<stdlib.h>
            #include<stdio.h>
            struct dlist  //雙向鏈表結(jié)構(gòu)聲明
            {
               int data;
               struct dlist *front;//指向下一結(jié)點(diǎn)的指針
               struct dlist *back; //指向前一結(jié)點(diǎn)的指針
            };
            typedef struct dlist dnode;//雙向鏈表新類型
            typedef dnode *dlink;//雙向鏈表指針新類型
            void printdlist(dlink head)
            {
               while (head!=NULL)
               {
                  printf("[%d]",head->data);
              head=head->front;
                }
            printf("\n");
            }
            //雙向鏈表結(jié)點(diǎn)的插入
            dlink insertnode(dlink head,dlink ptr,int value)
            {
               dlink new_node;
               //創(chuàng)建新結(jié)點(diǎn),分配結(jié)點(diǎn)內(nèi)存
               new_node=(dlink)malloc(sizeof(dnode));
               if(!new_node)
               return NULL;
               new_node->data=value;
               new_node->front=NULL;
               new_node->back=NULL;
               
               if(head == NULL)
               return new_node;
               
               if(ptr == NULL)
               {
                   //第一種情況:插在第一個(gè)結(jié)點(diǎn)之前,成為鏈表開始
               new_node->front=head;
               head->back=new_node;
               head=new_node;
            }
            else
            {
               if(ptr->front == NULL)
               {
                  //第二種情況:插在鏈表的最后
              ptr->front=new_node;//最后結(jié)點(diǎn)指向新結(jié)點(diǎn)
              new_node->back=ptr;//新結(jié)點(diǎn)指回最后結(jié)點(diǎn)
            }
               else
               {
                  //第三種情況:插入結(jié)點(diǎn)至鏈表中間結(jié)點(diǎn)內(nèi)
              ptr->front->back=new_node;//下一結(jié)點(diǎn)指回新結(jié)點(diǎn)
              new_node->front=ptr->front;//新結(jié)點(diǎn)指向下一結(jié)點(diǎn)
              new_node->back=ptr; //新結(jié)點(diǎn)指回插入結(jié)點(diǎn)
              ptr->front=new_node; //插入結(jié)點(diǎn)指向新結(jié)點(diǎn)
            }
            }
            return head;//返回鏈表起始指針
            }
            //主程序:使用插入結(jié)點(diǎn)的方式來創(chuàng)建鏈表,完成后將鏈表內(nèi)容輸出
            void main()
            {
               dlink head = NULL;//循環(huán)鏈表指針
               dlink tail = NULL;//鏈表最后的指針
               int list[6]={1,2,3,4,5,6};
               int i;
               head = insertnode(head,head,list[0]);
               printdlist(head);
               tail = head;//保留鏈表最后指針
               //第一種情況:插在第一個(gè)結(jié)點(diǎn)之前
               head=insertnode(head,NULL,list[1]);
               printdlist(head);
               //第二種情況:插在鏈表的最后
               head = insertnode(head,tail,list[2]);
               printdlist(head);
               for(i=3;i<6;i++)
               {
                  //第三種情況:插入結(jié)點(diǎn)至鏈表中間結(jié)點(diǎn)內(nèi)
              head = insertnode(head,head,list[i]);
              printdlist(head);
                }
            }
            性欧美丰满熟妇XXXX性久久久| 四虎国产精品成人免费久久| 精品久久一区二区三区| 久久精品国产一区| 久久久这里有精品| 久久九九亚洲精品| 久久久久久精品免费看SSS| 狠狠久久亚洲欧美专区| 久久只这里是精品66| 国产精品一久久香蕉产线看| 深夜久久AAAAA级毛片免费看| 国产毛片欧美毛片久久久| 99久久婷婷国产综合精品草原 | 久久精品国产福利国产琪琪| 亚洲中文精品久久久久久不卡| 91精品国产91久久久久久蜜臀| 久久热这里只有精品在线观看| 岛国搬运www久久| 国内精品久久国产大陆| 亚洲AV无码1区2区久久 | 一本大道久久东京热无码AV| 久久se精品一区精品二区| 日本久久久久亚洲中字幕| 亚洲欧美一级久久精品| 精品久久久久久无码中文野结衣| 国产精品美女久久久久久2018| 久久精品国产男包| 伊人久久一区二区三区无码| 久久亚洲AV永久无码精品| 99久久精品无码一区二区毛片 | 亚洲精品WWW久久久久久| 激情五月综合综合久久69| 久久久久夜夜夜精品国产| 成人免费网站久久久| 国产精品免费福利久久| 久久精品黄AA片一区二区三区| 久久超碰97人人做人人爱| 97久久精品人妻人人搡人人玩 | 精品无码久久久久国产| 好久久免费视频高清| 国产精品伊人久久伊人电影|