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

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

C語言數據結構 link 鏈表反轉的實現

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

C語言數據結構 link 鏈表反轉的實現

鏈表反轉,示例如下:

偶數個輸入:a->b->c->d->e->f
偶數個輸出:e->f->c->d->a->b
or
奇數個輸入:a->b->c->d->e->f->g
偶數個輸出:g->e->f->c->d->a->b

#include <stdio.h> #include <malloc.h>  #include <stdlib.h>  /************** start of stack *************/  #define STACK_SIZE 1024  char stack[STACK_SIZE]; int top = 0;  void push(char ch){   stack[top] = ch;   top++; }  char pop(){   top--;   return stack[top]; }  int isempty(){   return 0 == top; }  void test_stack(){   push('a');   push('b');   push('c');   push('d');    while(!isempty()){     printf("pop ch: %c/n", pop());   } }  /************** end of stack *************/     struct _node{   char data;   struct _node *next; };  typedef struct _node node, *plink;   plink init_link(){   plink pl;   pl = (plink)malloc(sizeof(node));      // check malloc success or not   if(NULL == pl) {     printf("malloc memory fail...");     return NULL;   }      // init link head   pl->data = '/0';   pl->next = NULL;      return pl; }  void input_data(plink pl, char data){   plink p = pl;      while(p->next){     p = p->next;   }      plink node = NULL;   node = (plink)malloc(sizeof(node));   // malloc a new node      // add data   if(NULL != node){     node->data = data;     node->next = p->next;    // last next is NULL     p->next = node;     p = node;          // p point last node   } }  void output_link(plink pl){   if(NULL == pl){     printf("plink is null");     return;   }      plink p = pl->next;  // already check pl is NULL, so here is ok   while(NULL != p){     printf("%c -> ", p->data);     p = p->next;   }    printf("/n/n");     }    // push and pop stack plink revert_link2(plink pl){   plink p = pl;    while(p->next){ //    printf("p->data: %c/n", p->next->data);     if(p->next->next){       push(p->next->next->data);       push(p->next->data);       p = p->next->next;     } else {       push(p->next->data);       p = p->next;     }   }    while(!isempty()){     printf("%c -> ", pop());   }      printf("/n/n");    return NULL; }    plink revert_link(plink pl){   if(NULL == pl){  // check link is NULL     return NULL;   }      int link_len = 0;   plink tmp_pl = pl->next;      while(tmp_pl){  // count link count     link_len++;     tmp_pl = tmp_pl->next;   }      // link length is no more than two node(s)   if(link_len <= 2){     return pl;   }      // link length is more than two nodes   return revert_link2(pl); }     int main(){   plink pl = NULL;      pl = init_link();     // init link head      input_data(pl, 'a');   // add data   input_data(pl, 'b');   input_data(pl, 'c');   input_data(pl, 'd');   input_data(pl, 'e');   input_data(pl, 'f');   input_data(pl, 'g');      output_link(pl);      plink pl2 = revert_link(pl);      output_link(pl2);    return 0; }    /**** revert_link.c   linux gcc compile gcc revert_link.c -o revert_link && ./revert_link   output result:  a -> b -> c -> d -> e -> f -> g g -> e -> f -> c -> d -> a -> b  or  a -> b -> c -> d -> e -> f e -> f -> c -> d -> a -> b   ****/ 

間隔螺旋反轉:

輸入: a -> b -> c -> d -> e -> f
輸出: b -> a -> d -> c -> f -> e

plink revert_link3(plink pl){   if(NULL == pl){     printf("plink is null");     return NULL;     }      plink p = pl;   plink first = p->next;   while(NULL != first){     plink second = first->next;     if(NULL != second){       first->next = second->next;   // third node       second->next = first;      // revert two nodes       first = first->next;       p->next = second;       p = second->next;     }   }   return pl; } 

如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产手机视频精品| 成人做爰www免费看视频网站| 亚洲国产97在线精品一区| 欧美极品少妇xxxxⅹ喷水| 成人性生交xxxxx网站| 在线观看欧美www| 亚洲欧美在线免费| 亚洲欧美综合另类中字| 国产精品中文字幕在线| 8050国产精品久久久久久| 国产精品欧美一区二区| 国产福利精品av综合导导航| 欧美视频在线看| 日韩一级裸体免费视频| 日本三级韩国三级久久| 亚洲欧美日本另类| 人人澡人人澡人人看欧美| 色偷偷888欧美精品久久久| 91丨九色丨国产在线| 中文字幕视频在线免费欧美日韩综合在线看| 国产成人aa精品一区在线播放| 午夜精品视频在线| 国产中文字幕亚洲| 亚洲天堂成人在线视频| 久久网福利资源网站| 97久久国产精品| 国产香蕉一区二区三区在线视频| 成人国内精品久久久久一区| 亚洲综合色激情五月| 国产精品第10页| 欧美日韩国产中文字幕| 综合av色偷偷网| 欧美黑人极品猛少妇色xxxxx| 亚洲美女av在线| 亚洲天堂久久av| 亚洲精品久久久一区二区三区| 久久精品一本久久99精品| 精品无人国产偷自产在线| 青青草原成人在线视频| 国产日韩在线一区| 国产成人精品午夜| 日韩欧中文字幕| 欧美一级片在线播放| 欧美激情在线狂野欧美精品| 高清欧美电影在线| 欧美日韩免费在线| 日韩网站免费观看高清| 日韩精品福利网站| 国产精品av在线播放| 久久精品91久久久久久再现| 51久久精品夜色国产麻豆| 亚洲激情视频在线观看| 中文字幕在线看视频国产欧美在线看完整| 97在线精品视频| 国产精品一区二区三区毛片淫片| 日韩最新中文字幕电影免费看| 久久国产精品视频| 久久99热这里只有精品国产| 欧美超级乱淫片喷水| 久久精品国产一区二区三区| 日韩第一页在线| 亚洲毛片在线观看.| 国产精品自产拍在线观看| 国产精品日韩在线播放| 亚洲一区二区福利| 日韩视频免费在线| 8x海外华人永久免费日韩内陆视频| 538国产精品一区二区在线| 欧美性猛交xxxx乱大交3| 日韩黄色av网站| 日韩美女av在线免费观看| 在线电影欧美日韩一区二区私密| 亚洲成**性毛茸茸| 亚洲free性xxxx护士hd| 国产视频精品xxxx| 欧美精品在线极品| 亚洲欧美激情一区| 日韩人体视频一二区| 91精品久久久久久| 亚洲va欧美va国产综合剧情| 91久久久久久久久久| 国产精品久久999| 色999日韩欧美国产| 欧美重口另类videos人妖| 另类专区欧美制服同性| 亚洲第一精品电影| 激情懂色av一区av二区av| 国内偷自视频区视频综合| 久久久精品2019中文字幕神马| 欧美激情欧美狂野欧美精品| 国产精品爽爽爽爽爽爽在线观看| 成人午夜激情免费视频| 亚洲国产精品成人精品| 青青精品视频播放| 亚洲女人天堂成人av在线| 久久99热精品这里久久精品| 日韩视频免费中文字幕| 国产欧美精品日韩精品| 欧美日韩爱爱视频| 亚洲美腿欧美激情另类| 国产精品羞羞答答| 亚洲精品videossex少妇| 国产精品稀缺呦系列在线| 国产美女久久精品香蕉69| 亚洲激情在线观看视频免费| 成人精品在线视频| 亚洲色无码播放| 日本午夜在线亚洲.国产| 亚洲3p在线观看| zzjj国产精品一区二区| 91午夜在线播放| 亚洲美女又黄又爽在线观看| 久久久国产成人精品| 国产精品久久久久久久久久| 亚洲最大激情中文字幕| 国产精品成人免费电影| 日韩av一区在线观看| 热久久免费视频精品| 国产精品人人做人人爽| 午夜精品一区二区三区视频免费看| 69影院欧美专区视频| 欧美xxxx18性欧美| 日韩精品在线影院| 精品日本美女福利在线观看| 国产网站欧美日韩免费精品在线观看| 国产自摸综合网| 欧美成人精品影院| 欧美激情欧美狂野欧美精品| 日av在线播放中文不卡| 亚洲欧美一区二区精品久久久| 精品久久久久久| 久久香蕉国产线看观看av| 国产精品成av人在线视午夜片| 国产精品入口尤物| 色爱精品视频一区| 亚洲精品视频播放| 欧美一级淫片videoshd| 久久久久久91香蕉国产| 色偷偷av亚洲男人的天堂| 丝袜亚洲欧美日韩综合| 精品无码久久久久久国产| 国内精品国产三级国产在线专| 欧美色播在线播放| 久久人人爽人人爽人人片av高清| 国产精品视频播放| 欧美性生交大片免费| 欧美激情高清视频| 日av在线播放中文不卡| 成人精品在线观看| 精品动漫一区二区| 午夜精品蜜臀一区二区三区免费| 成人h片在线播放免费网站| 欧美日韩国产精品一区| 日韩av电影在线免费播放| 欧美一区二区三区……| 成人福利免费观看| 不卡av在线网站| 日韩女在线观看| 亚洲第一男人av| 欧美有码在线视频| 中文字幕自拍vr一区二区三区| 亚洲成人av片在线观看| 日本精品久久电影| 久久91超碰青草是什么|