亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

C語言數據結構實現鏈表逆序并輸出

2020-01-26 14:11:11
字體:
來源:轉載
供稿:網友

C語言數據結構實現鏈表逆序并輸出

將一個鏈表逆序并輸出。我用了兩種方法來實現,第一種是借助了一個新的空鏈表;第二種是在原來鏈表的基礎上直接實現逆序。

實例代碼:

    頭文件:  

#include <stdio.h> #include <stdlib.h> #include <malloc.h> typedef int ElemType; typedef struct Node {//結點結構  ElemType value;    //值域  struct Node *next;//指針域 }Node,*ptr_Node; typedef struct LinkList {//鏈表結構  ptr_Node head; //鏈表頭結點指針  ptr_Node tail;//鏈表尾結點指針  int length;  //鏈表長度 }LinkList,*ptr_LinkList; ptr_LinkList CreateList(void) {//創建一個空鏈表  ptr_LinkList linklist;  linklist=(LinkList *)malloc(sizeof(LinkList));  if(!linklist)  {   printf("allocation failed./n");  }  linklist->head=NULL;  linklist->tail=NULL;  linklist->length=0;  return linklist; } bool IsListEmpty(ptr_LinkList linklist) {//判斷鏈表是否為空  if(linklist->length==0)  {   return true;  }  return false; } void InsertListHead(ptr_LinkList linklist,ElemType element) {//在表頭插入值為element的結點作為新的表頭  ptr_Node ptr_node;  ptr_node=(Node *)malloc(sizeof(Node)); //生成插入結點  if(!ptr_node)  {   printf("allocation failed./n");  }  else  {   ptr_node->value=element;   if(linklist->length==0)   {    linklist->head=ptr_node;    linklist->tail=linklist->head;    linklist->tail->next=NULL;   }   else   {    ptr_node->next=linklist->head;    linklist->head=ptr_node; //鏈表頭   }   linklist->length++; //鏈表長度加1  } } void InsertListTail(ptr_LinkList linklist,ElemType element) {  ptr_Node ptr_node;  ptr_node=(Node *)malloc(sizeof(Node)); //生成插入結點  if(!ptr_node)  {   printf("allocation failed./n");  }  else  {   ptr_node->value=element;   if(linklist->length==0)   {    linklist->head=ptr_node;    linklist->tail=linklist->head;    linklist->tail->next=NULL;   }   else   {    linklist->tail->next=ptr_node;    linklist->tail=ptr_node; //鏈表尾   }   linklist->length++; //鏈表長度加1  } } void InsertListPosition(ptr_LinkList linklist,int pos,ElemType element) {  int i;  ptr_Node ptr_node;  ptr_Node temp_ptr_node;  if(pos<1 || pos>linklist->length)  {   printf("The insert position is invalidate./n");  }  else  {   ptr_node=(Node *)malloc(sizeof(Node)); //生成插入結點   if(!ptr_node)   {    printf("allocation failed./n");   }   ptr_node->value=element;   if(pos==1)   {    InsertListHead(linklist,element);   }   else if(pos==linklist->length)   {    InsertListTail(linklist,element);   }   else   {    temp_ptr_node=linklist->head;    for(i=1;i<pos-1;i++)    {//找到第pos-1個結點     temp_ptr_node=temp_ptr_node->next;    }    ptr_node->next=temp_ptr_node->next;    temp_ptr_node->next=ptr_node;    linklist->length++;   }  } } void Destroy(ptr_LinkList linklist) {//銷毀鏈表  ptr_Node p=linklist->head;  ptr_Node q;  while(p)  {//釋放每個結點空間   q=p->next;   free(p);   p=NULL;   p=q;  } } void Traverse(ptr_LinkList linklist) {//輸出整個鏈表  ptr_Node p;  p=linklist->head;  while(p)  {   printf("%4d",p->value);   p=p->next;  } }

    頭文件中實現了鏈表的幾個基本的操作,有的是必須的,有些是非必須的。

    實現代碼:  

#include "stdafx.h" #include "LinkList.h" #include <conio.h> ptr_LinkList InvertList(ptr_LinkList list) {//該方法借助一個新的空鏈表來實現鏈表逆序  ptr_LinkList inverted_linklist;  ptr_Node p;  p=list->head;  inverted_linklist=CreateList();//創建一個空鏈表  while(p)  {//將list鏈表中的結點值逆序輸入新創建的鏈表中,實現鏈表反轉   InsertListHead(inverted_linklist,p->value);   p=p->next;  }  return inverted_linklist; } void InvertLinkList(ptr_LinkList linklist) {//該方法直接對原有鏈表實現逆序,不借助其他鏈表  ptr_Node p,q,r,m;  m=p=linklist->head;  q=p->next;  r=q->next;  while(r)  {//依次對鏈表中的結點進行反轉   q->next=p;   p=q;   q=r;   r=r->next;  }  q->next=p; //最后一個結點反轉  linklist->head=q;  linklist->tail=m;  linklist->tail->next=NULL; } int _tmain(int argc, _TCHAR* argv[]) {  ptr_LinkList linklist;  ptr_LinkList list;  linklist=CreateList();  if(linklist)  {   printf("We have created a new linklist./n");  }  InsertListHead(linklist,12);  InsertListHead(linklist,35);  InsertListHead(linklist,66);  InsertListHead(linklist,06);  InsertListHead(linklist,11);  InsertListHead(linklist,54);  InsertListHead(linklist,79);  Traverse(linklist);  printf("/n");  printf("The first method:/n");  list=InvertList(linklist);  Traverse(list);  printf("/n");  printf("The second method:/n");  InvertLinkList(linklist);  Traverse(linklist);  printf("/n");  getch();  return 0; } 

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品电影一区| 亚洲成人久久久久| 日本精品视频在线播放| 色综合色综合网色综合| 色av中文字幕一区| 日韩高清免费观看| 91a在线视频| 国产中文日韩欧美| 日本久久亚洲电影| 欧美网站在线观看| 98精品国产高清在线xxxx天堂| 国产成人精品免高潮费视频| 成人欧美一区二区三区在线| 亚洲最大成人免费视频| 日韩精品丝袜在线| 日韩av手机在线观看| 成人在线观看视频网站| 欧美国产在线视频| 精品国偷自产在线视频| 国产精品一区二区在线| 国精产品一区一区三区有限在线| 国产在线日韩在线| 日韩av免费在线观看| 久久久成人精品视频| 成人97在线观看视频| 国产精品久久久久久亚洲影视| 欧美重口另类videos人妖| 亚洲久久久久久久久久| 8090成年在线看片午夜| 国产美女91呻吟求| 日韩av片电影专区| 久久香蕉国产线看观看av| 久久久久久噜噜噜久久久精品| 久久亚洲春色中文字幕| 久久久久久一区二区三区| 欧美激情在线观看视频| 91久久久久久国产精品| 日本久久久a级免费| 亚洲欧美精品一区二区| 日韩精品中文字幕久久臀| 精品国产91久久久久久| 97国产一区二区精品久久呦| 日韩av免费观影| 精品国偷自产在线视频| 日韩免费看的电影电视剧大全| 亚洲伊人一本大道中文字幕| 久久久亚洲天堂| 亚洲国产精久久久久久| 日韩欧美在线视频观看| 亚洲天堂av电影| 91探花福利精品国产自产在线| 青草青草久热精品视频在线观看| 麻豆精品精华液| 国产综合在线视频| 成人做爰www免费看视频网站| 成人午夜高潮视频| 亚洲一级黄色av| 国产亚洲精品91在线| 91系列在线观看| 国产精品video| 国产精品久久久久久五月尺| 日韩精品中文字幕在线播放| 91亚洲精品视频| 亚洲第一精品久久忘忧草社区| 日韩中文字幕在线免费观看| 亚洲国产精品久久久久秋霞蜜臀| 欧美与黑人午夜性猛交久久久| 97在线免费视频| 欧洲成人午夜免费大片| 亚洲品质视频自拍网| 国产精品欧美风情| 亚洲美女中文字幕| 九九九热精品免费视频观看网站| 亚洲综合成人婷婷小说| 亚洲系列中文字幕| 欧美成人免费全部观看天天性色| 97视频在线观看免费| 久久精品国产久精国产一老狼| 久久精品亚洲热| 精品国偷自产在线视频99| 久久国产精品偷| 亚洲国产欧美一区| 色偷偷噜噜噜亚洲男人的天堂| 国产精品中文在线| 97涩涩爰在线观看亚洲| 精品人伦一区二区三区蜜桃免费| 69国产精品成人在线播放| 91在线无精精品一区二区| 欧美日韩不卡合集视频| 久久久成人的性感天堂| 日韩视频在线免费| 国产亚洲欧美aaaa| 国产精品久久精品| 亚洲电影av在线| 亚洲女人天堂视频| 久久亚洲影音av资源网| 欧美性猛交xxxx黑人猛交| 亚洲娇小xxxx欧美娇小| 欧美午夜丰满在线18影院| 日韩av不卡电影| 久久国产精品久久久久久久久久| 欧美日韩福利电影| 亚洲高清av在线| 日韩一区二区三区在线播放| 国产极品jizzhd欧美| 日韩av一卡二卡| 国产精品一区二区久久国产| 欧美性视频网站| 亚洲女人初尝黑人巨大| 亚洲a中文字幕| 欧美成人精品在线| 日韩av在线网址| 成人黄色免费片| 国产精品日韩欧美| 在线观看免费高清视频97| 一二美女精品欧洲| 亚洲国产私拍精品国模在线观看| 成人欧美一区二区三区黑人| 日韩美女av在线| 国产精品入口免费视频一| 中文字幕最新精品| 国产伦精品一区二区三区精品视频| 亚洲欧美国产日韩中文字幕| 亚洲va欧美va国产综合久久| 一本色道久久88亚洲综合88| 久久精品国产成人| 成人精品福利视频| 成人欧美一区二区三区黑人| 国产精品扒开腿做| 中文字幕在线观看日韩| 欧美天天综合色影久久精品| 欧美日韩另类在线| 亚洲福利视频网站| 青青草成人在线| 伊人久久大香线蕉av一区二区| 91av在线影院| 18久久久久久| 亚洲3p在线观看| 亚洲影院高清在线| 日韩av手机在线看| 亚洲国产一区二区三区四区| 亚洲自拍偷拍色片视频| 国产精品久久电影观看| 国产一区二区视频在线观看| 久久全球大尺度高清视频| 国产精品丝袜白浆摸在线| 亚洲激情免费观看| 日韩一区二区三区在线播放| 亚洲高清av在线| 51ⅴ精品国产91久久久久久| 97久久精品视频| 欧美日韩国产在线看| 51精品在线观看| 久久久久国产精品免费| 欧美精品午夜视频| 国产区精品视频| 亚洲最大激情中文字幕| 亚洲欧美国产精品久久久久久久| 亚洲a中文字幕| 久久精品精品电影网| 中文字幕亚洲色图| 久久久久亚洲精品成人网小说| 国产日韩在线观看av| 国产精品丝袜一区二区三区|