找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2149|回复: 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 单片机教程网

快速回复 返回顶部 返回列表