链表逆序

 (2012-03-08 05:03)
分类:  LinK_List


设链表节点为
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 (= 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 (!= 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 (!= 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. }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值