免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
鏈表逆序

  1. typedef struct tagListNode{  
  2.     int data;  
  3.     struct tagListNode* next;  
  4. }ListNode, *List;  

要求將一帶鏈表頭List head的單向鏈表逆序。

分析:

  1). 若鏈表為空或只有一個元素,則直接返回;

  2). 設(shè)置兩個前后相鄰的指針p,q. 將p所指向的節(jié)點作為q指向節(jié)點的后繼;

  3). 重復(fù)2),直到q為空

  4). 調(diào)整鏈表頭和鏈表尾

示例:以逆序A->B->C->D為例,圖示如下

 

實現(xiàn)及測試代碼如下:

[cpp:nogutter] view plaincopy?
  1. #include <stdio.h>  
  2. #include <stdlib.h>  
  3.   
  4. typedef struct tagListNode{  
  5.     int data;  
  6.     struct tagListNode* next;  
  7. }ListNode, *List;  
  8.   
  9. void PrintList(List head);  
  10. List ReverseList(List head);  
  11.   
  12. int main()  
  13. {  
  14.     //分配鏈表頭結(jié)點  
  15.     ListNode *head;  
  16.     head = (ListNode*)malloc(sizeof(ListNode));  
  17.     head->next = NULL;  
  18.     head->data = -1;  
  19.   
  20.     //將[1,10]加入鏈表  
  21.     int i;  
  22.     ListNode *p, *q;  
  23.     p = head;  
  24.     for(int i = 1; i <= 10; i++)  
  25.     {  
  26.         q = (ListNode *)malloc(sizeof(ListNode));  
  27.         q->data = i;  
  28.         q->next = NULL;  
  29.         p->next = q;  
  30.         p = q;          
  31.     }  
  32.   
  33.     PrintList(head);           /*輸出原始鏈表*/  
  34.     head = ReverseList(head);  /*逆序鏈表*/  
  35.     PrintList(head);           /*輸出逆序后的鏈表*/  
  36.     return 0;  
  37. }  
  38.   
  39. List ReverseList(List head)  
  40. {  
  41.     if(head->next == NULL || head->next->next == NULL)    
  42.     {  
  43.        return head;   /*鏈表為空或只有一個元素則直接返回*/  
  44.     }  
  45.   
  46.     ListNode *t = NULL,  
  47.              *p = head->next,  
  48.              *q = head->next->next;  
  49.     while(q != NULL)  
  50.     {          
  51.       t = q->next;  
  52.       q->next = p;  
  53.       p = q;  
  54.       q = t;  
  55.     }  
  56.   
  57.     /*此時q指向原始鏈表最后一個元素,也是逆轉(zhuǎn)后的鏈表的表頭元素*/  
  58.     head->next->next = NULL;  /*設(shè)置鏈表尾*/  
  59.     head->next = p;           /*調(diào)整鏈表頭*/  
  60.     return head;  
  61. }  
  62.   
  63. void PrintList(List head)  
  64. {  
  65.     ListNode* p = head->next;  
  66.     while(p != NULL)  
  67.     {  
  68.         printf("%d ", p->data);  
  69.         p = p->next;  
  70.     }  
  71.     printf("/n");  
  72. }  

本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
單鏈表的逆置
鏈表的逆序?qū)崿F(xiàn)
單向鏈表、雙向鏈表,棧,隊列的C語言的實現(xiàn)方法
詳解雙向鏈表的基本操作(C語言)
劍指offer 03 從尾到頭打印鏈表
面試不可不會的單鏈表反轉(zhuǎn)
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服