Chinaunix首页 | 论坛 | 博客
  • 博客访问: 52511
  • 博文数量: 25
  • 博客积分: 166
  • 博客等级: 入伍新兵
  • 技术积分: 177
  • 用 户 组: 普通用户
  • 注册时间: 2011-12-28 08:57
文章分类

全部博文(25)

文章存档

2015年(2)

2013年(1)

2012年(18)

2011年(4)

我的朋友

分类:

2012-04-13 10:21:23

原文地址:链表逆序 作者:

设链表节点为
typedef struct node {
    int data;
    struct node *next;
}node_t, *pnode_t;

要求将一带链表头List head的单向链表逆序。

分析:

  1). 若链表为空或只有一个元素,则直接返回;

  2). 设置两个前后相邻的指针p,q. 将p所指向的节点作为q指向节点的后继;

  3). 重复2),直到q为空

  4). 调整链表头和链表尾

示例:以逆序A->B->C->D为例,图示如下

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>

  4. #define LEN 10

  5. typedef struct node {
  6.     int data;
  7.     struct node *pnext;
  8. } node_t, *pnode_t;

  9. pnode_t create_link()
  10. {
  11.     int i;
  12.     pnode_t phead;

  13.     phead = (pnode_t)malloc(sizeof(node_t));    
  14.     if (phead == NULL) {
  15.         printf("malloc fail.\n");
  16.         exit(-1);
  17.     }
  18.     memset(phead, 0, sizeof(node_t));

  19.     pnode_t ptail = phead;

  20.     for (i = 0; i < LEN; i++) {
  21.         pnode_t    pnew = (pnode_t)malloc(sizeof(node_t));
  22.         if (pnew == NULL) {
  23.             printf("malloc fail.\n");
  24.             exit(-1);
  25.         }
  26.         memset(pnew, 0, sizeof(node_t));

  27.         pnew->data = i+1;
  28.         pnew->pnext = NULL;
  29.         ptail->pnext = pnew;
  30.         ptail = pnew;
  31.     }

  32.     return phead;
  33. }

  34. void print_link(pnode_t phead)
  35. {
  36.     pnode_t p = phead->pnext;

  37.     while (p != NULL) {
  38.         printf("%d ", p->data);
  39.         p = p->pnext;
  40.     }
  41.     printf("\n");
  42. }

  43. void reverse_link(pnode_t phead)
  44. {
  45.     pnode_t p, q, ptmp;

  46.     p = phead->pnext;
  47.     q = phead->pnext->pnext;
  48.     ptmp = NULL;

  49.     while (q != NULL) {
  50.         ptmp = q->pnext;
  51.         q->pnext = p;
  52.         p = q;
  53.         q = ptmp;
  54.     }

  55.     phead->pnext->pnext = NULL;
  56.     phead->pnext = p;
  57. }

  58. int main(int argc, char *argv[])
  59. {
  60.     pnode_t phead = NULL;

  61.     phead = create_link();

  62.     print_link(phead);

  63.     reverse_link(phead);
  64.     print_link(phead);

  65.     return 0;
  66. }



阅读(489) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~