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

首頁 > 編程 > C++ > 正文

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

2020-05-23 13:47:33
字體:
來源:轉載
供稿:網友

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| 中文亚洲视频在线| 亚洲xxxxx性| 91精品视频播放| 欧美激情视频在线| 国产成人av网址| 精品中文字幕在线观看| 日韩免费观看在线观看| 538国产精品视频一区二区| 亚洲精品www久久久久久广东| 福利一区福利二区微拍刺激| 4438全国亚洲精品在线观看视频| 亚洲国产精品va| 久久久久久久久久久av| 69视频在线免费观看| 亚洲国产精彩中文乱码av在线播放| 亚洲国产免费av| 福利一区福利二区微拍刺激| 亚洲一区二区久久久久久久| 精品调教chinesegay| 国产噜噜噜噜噜久久久久久久久| 成人做爽爽免费视频| 国产欧美一区二区三区久久人妖| 中文欧美在线视频| 日韩一区二区在线视频| 国产精品久久久久久五月尺| 亚洲有声小说3d| 在线亚洲午夜片av大片| 乱亲女秽乱长久久久| 国产a∨精品一区二区三区不卡| 亚洲成人av在线| 日韩在线观看免费高清完整版| 91精品视频一区| 91色视频在线观看| 亚洲直播在线一区| 一本色道久久88综合日韩精品| 欧美在线一级va免费观看| 国产精品私拍pans大尺度在线| 亚洲精品999| 色综合久久天天综线观看| 午夜精品久久久久久久男人的天堂| 成人国产精品免费视频| 国产精品pans私拍| 亚洲精品网址在线观看| 日韩av在线高清| 亚洲第一精品夜夜躁人人躁| 57pao国产成人免费| 日韩美女中文字幕| 欧美久久精品一级黑人c片| 久久躁狠狠躁夜夜爽| 国产日韩在线精品av| 在线播放日韩欧美| 成人综合国产精品| 欧美天天综合色影久久精品| 国产激情久久久久| 欧美大胆在线视频| 国产一区二区三区毛片| 庆余年2免费日韩剧观看大牛| 国产精品久久久久av| 久久精品99久久久久久久久| 红桃视频成人在线观看| 中文字幕日韩有码| 亚洲精品理论电影| 亚洲最大的成人网| 2020久久国产精品| 97人人模人人爽人人喊中文字| 欧美重口另类videos人妖| 久久av在线看| 久久久久久国产精品美女| 97av在线视频| 91精品久久久久久久久不口人| 日韩av综合网站| 在线电影欧美日韩一区二区私密| 美日韩丰满少妇在线观看| 亚洲视频专区在线| 美日韩精品视频免费看| 亚洲网站在线看| 91久久中文字幕| 亚洲淫片在线视频| 日韩在线观看免费| 久久精品91久久久久久再现| 狠狠色狠狠色综合日日五| 亚洲电影免费观看高清完整版在线观看| 亚洲japanese制服美女| 91高清免费视频| 美乳少妇欧美精品| 国产精品偷伦一区二区| 亚洲精品动漫久久久久| 欧美人成在线视频| 成人精品aaaa网站| 午夜精品蜜臀一区二区三区免费| 国产精品美腿一区在线看| 亚洲图片欧洲图片av| 欧美激情一区二区三区在线视频观看| 欧美国产日韩中文字幕在线| 久久精品国产免费观看| 日韩欧美在线中文字幕| 久久香蕉国产线看观看网| 主播福利视频一区| 国产精品69久久久久| 成人网页在线免费观看| 国产精品久久久久久久久久免费| 日韩中文在线中文网三级| 亚洲精品电影网在线观看| 国产欧美在线观看| 国产精品色午夜在线观看| 久久99热这里只有精品国产| 久久久中文字幕| 久久91精品国产| 日韩有码视频在线| 欧美片一区二区三区| 亚洲国产欧美一区二区三区同亚洲| 性欧美亚洲xxxx乳在线观看| 国产日韩欧美另类| 一二美女精品欧洲| 91精品国产综合久久香蕉最新版| 国产精品色午夜在线观看| 国产精品成人aaaaa网站| 亚洲国产一区二区三区四区| 成人免费观看a| 亚洲第一综合天堂另类专| 久久乐国产精品| 亚洲女成人图区| 97国产suv精品一区二区62| 91精品久久久久久久久久久| 中文在线不卡视频| 国产精品久久久久久久久久三级| 日韩av成人在线观看| 国产91亚洲精品| 成人黄色片在线| 91国产视频在线| 成人精品网站在线观看| 日韩在线观看免费全集电视剧网站| 亚洲视频在线观看网站| 欧美日韩一区二区免费视频| 色妞一区二区三区| 国产99久久精品一区二区永久免费| 欧美高清性猛交| 成人黄色片网站| 亚洲高清福利视频| 国产精品99久久久久久久久久久久| 亚洲男人第一网站| 国产精品自拍小视频| 欧美性极品少妇精品网站| 色悠悠国产精品| 亚洲自拍偷拍区| 日本一本a高清免费不卡| 亚洲精品久久久久久久久久久久| 91高清免费在线观看| 久久久电影免费观看完整版| 成人在线中文字幕| 欧美在线视频网| 色噜噜狠狠狠综合曰曰曰88av| 国产一区二区三区欧美| 欧美激情一二区| 欧美精品videossex性护士| 69国产精品成人在线播放| 一区二区三区日韩在线|