• <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++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            雙向鏈表內結點的插入

            Posted on 2012-02-28 00:35 hoshelly 閱讀(636) 評論(0)  編輯 收藏 引用 所屬分類: DS && Algorithm
            #include<stdlib.h>
            #include<stdio.h>
            struct dlist  //雙向鏈表結構聲明
            {
               int data;
               struct dlist *front;//指向下一結點的指針
               struct dlist *back; //指向前一結點的指針
            };
            typedef struct dlist dnode;//雙向鏈表新類型
            typedef dnode *dlink;//雙向鏈表指針新類型
            void printdlist(dlink head)
            {
               while (head!=NULL)
               {
                  printf("[%d]",head->data);
              head=head->front;
                }
            printf("\n");
            }
            //雙向鏈表結點的插入
            dlink insertnode(dlink head,dlink ptr,int value)
            {
               dlink new_node;
               //創建新結點,分配結點內存
               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)
               {
                   //第一種情況:插在第一個結點之前,成為鏈表開始
               new_node->front=head;
               head->back=new_node;
               head=new_node;
            }
            else
            {
               if(ptr->front == NULL)
               {
                  //第二種情況:插在鏈表的最后
              ptr->front=new_node;//最后結點指向新結點
              new_node->back=ptr;//新結點指回最后結點
            }
               else
               {
                  //第三種情況:插入結點至鏈表中間結點內
              ptr->front->back=new_node;//下一結點指回新結點
              new_node->front=ptr->front;//新結點指向下一結點
              new_node->back=ptr; //新結點指回插入結點
              ptr->front=new_node; //插入結點指向新結點
            }
            }
            return head;//返回鏈表起始指針
            }
            //主程序:使用插入結點的方式來創建鏈表,完成后將鏈表內容輸出
            void main()
            {
               dlink head = NULL;//循環鏈表指針
               dlink tail = NULL;//鏈表最后的指針
               int list[6]={1,2,3,4,5,6};
               int i;
               head = insertnode(head,head,list[0]);
               printdlist(head);
               tail = head;//保留鏈表最后指針
               //第一種情況:插在第一個結點之前
               head=insertnode(head,NULL,list[1]);
               printdlist(head);
               //第二種情況:插在鏈表的最后
               head = insertnode(head,tail,list[2]);
               printdlist(head);
               for(i=3;i<6;i++)
               {
                  //第三種情況:插入結點至鏈表中間結點內
              head = insertnode(head,head,list[i]);
              printdlist(head);
                }
            }
            国产Av激情久久无码天堂| 欧美亚洲另类久久综合婷婷| 久久人人爽人人爽人人片AV不| 69久久夜色精品国产69| 久久99精品久久久久子伦| 久久久久久国产精品免费免费 | 伊人伊成久久人综合网777| 久久性精品| 亚洲日本va中文字幕久久| 无码日韩人妻精品久久蜜桃 | 办公室久久精品| 亚洲欧美日韩久久精品第一区| 色综合久久88色综合天天 | 久久精品国产免费观看 | 久久久久人妻精品一区二区三区| 国产精品18久久久久久vr | 99精品久久精品| 中文字幕久久久久人妻| 久久综合久久鬼色| 91精品婷婷国产综合久久| 亚洲av成人无码久久精品| 麻豆精品久久久久久久99蜜桃| 91性高湖久久久久| 狠狠色婷婷综合天天久久丁香| 综合人妻久久一区二区精品| 亚洲AⅤ优女AV综合久久久| 久久99精品久久久久久9蜜桃 | 欧美日韩精品久久久久| AA级片免费看视频久久| 久久99国产亚洲高清观看首页| 久久久久亚洲Av无码专| 亚洲色欲久久久综合网东京热| 久久国产劲爆AV内射—百度| 亚洲精品乱码久久久久久不卡| 日韩十八禁一区二区久久| 欧美一区二区久久精品| 久久综合视频网| 嫩草伊人久久精品少妇AV| 久久人人爽爽爽人久久久| 精品999久久久久久中文字幕| 久久久久综合网久久|