久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2179|回復: 0
打印 上一主題 下一主題
收起左側

鏈表逆序

[復制鏈接]
跳轉到指定樓層
樓主
ID:108615 發表于 2016-3-13 16:58 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式

typedef struct tagListNode
      {  
        int data;  
        struct tagListNode* next;  
       }ListNode, *List;  


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

分析:

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

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

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

  4). 調整鏈表頭和鏈表尾

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


實現及測試代碼如下:


[cpp:nogutter] view plaincopyprint?
#include <stdio.h>   
#include <stdlib.h>   
  
typedef struct tagListNode{  
    int data;  
    struct tagListNode* next;  
}ListNode, *List;   
void PrintList(List head);  
List ReverseList(List head);  
int main()  
{  
    //分配鏈表頭結點   
    ListNode *head;  
    head = (ListNode*)malloc(sizeof(ListNode));  
    head->next = NULL;  
    head->data = -1;  
    //將[1,10]加入鏈表   
    int i;  
    ListNode *p, *q;  
    p = head;  
    for(int i = 1; i <= 10; i++)  
    {  
        q = (ListNode *)malloc(sizeof(ListNode));  
        q->data = i;  
        q->next = NULL;  
        p->next = q;  
        p = q;         
    }  
    PrintList(head);           /*輸出原始鏈表*/  
    head = ReverseList(head);  /*逆序鏈表*/  
    PrintList(head);           /*輸出逆序后的鏈表*/  
    return 0;  
}   
List ReverseList(List head)  
{  
    if(head->next == NULL || head->next->next == NULL)   
    {  
       return head;   /*鏈表為空或只有一個元素則直接返回*/  
    }  
    ListNode *t = NULL,  
     *p = head->next,  
    *q = head->next->next;  
    while(q != NULL)  
    {         
      t = q->next;  
      q->next = p;  
      p = q;  
      q = t;  
    }  
    /*此時q指向原始鏈表最后一個元素,也是逆轉后的鏈表的表頭元素*/  
    head->next->next = NULL;  /*設置鏈表尾*/  
    head->next = p;           /*調整鏈表頭*/  
    return head;  
}  
void PrintList(List head)  
{  
    ListNode* p = head->next;  
    while(p != NULL)  
    {  
        printf("%d ", p->data);  
        p = p->next;  
    }  
    printf("/n");  
}  



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 一区欧美 | 国产精品视频网站 | 国产精品久久久乱弄 | 国产91精品久久久久久久网曝门 | 亚洲激精日韩激精欧美精品 | 四虎在线视频 | 99精品国产一区二区三区 | 精品无码久久久久国产 | 国产99精品 | 精品欧美一区二区三区久久久小说 | 在线观看黄视频 | 伦理一区二区 | 午夜视频在线 | 日韩一区二区在线视频 | 99re热精品视频| www.久久精品 | 日韩aⅴ片 | 羞羞视频网站免费观看 | 欧美久久久网站 | 91麻豆精品国产91久久久更新资源速度超快 | 国产在线一区观看 | 欧美日韩免费视频 | 欧美日韩免费一区二区三区 | 在线国产视频观看 | 中文字幕在线观看日韩 | 在线国产中文字幕 | 国产精品久久久久久久7电影 | 三级在线视频 | 一区二区三区四区在线播放 | 久草精品视频 | 国产精品久久久久久久免费大片 | 国产激情视频 | 在线欧美视频 | 天天草视频 | 在线中文字幕视频 | 国产精品久久久久久久久久尿 | 国产精品久久国产精品久久 | 午夜综合 | 国产一区二区在线播放 | 亚洲精品电影网在线观看 | 日韩精品久久久久 |