分类: C/C++2010-10-23 17:23 18425人阅读 评论(22) 收藏 举报

设链表节点为

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

要求将一带链表头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. typedef struct tagListNode{
  4. int data;
  5. struct tagListNode* next;
  6. }ListNode, *List;
  7. void PrintList(List head);
  8. List ReverseList(List head);
  9. int main()
  10. {
  11. //分配链表头结点
  12. ListNode *head;
  13. head = (ListNode*)malloc(sizeof(ListNode));
  14. head->next = NULL;
  15. head->data = -1;
  16. //将[1,10]加入链表
  17. int i;
  18. ListNode *p, *q;
  19. p = head;
  20. for(int i = 1; i <= 10; i++)
  21. {
  22. q = (ListNode *)malloc(sizeof(ListNode));
  23. q->data = i;
  24. q->next = NULL;
  25. p->next = q;
  26. p = q;
  27. }
  28. PrintList(head);           /*输出原始链表*/
  29. head = ReverseList(head);  /*逆序链表*/
  30. PrintList(head);           /*输出逆序后的链表*/
  31. return 0;
  32. }
  33. List ReverseList(List head)
  34. {
  35. if(head->next == NULL || head->next->next == NULL)
  36. {
  37. return head;   /*链表为空或只有一个元素则直接返回*/
  38. }
  39. ListNode *t = NULL,
  40. *p = head->next,
  41. *q = head->next->next;
  42. while(q != NULL)
  43. {
  44. t = q->next;
  45. q->next = p;
  46. p = q;
  47. q = t;
  48. }
  49. /*此时q指向原始链表最后一个元素,也是逆转后的链表的表头元素*/
  50. head->next->next = NULL;  /*设置链表尾*/
  51. head->next = p;           /*调整链表头*/
  52. return head;
  53. }
  54. void PrintList(List head)
  55. {
  56. ListNode* p = head->next;
  57. while(p != NULL)
  58. {
  59. printf("%d ", p->data);
  60. p = p->next;
  61. }
  62. printf("/n");
  63. }

ZT 链表逆序的更多相关文章

  1. Reverse Linked List II 单向链表逆序(部分逆序)

    0 问题描述 原题点击这里. 将单向链表第m个位置到第n个位置倒序连接.例如, 原链表:1->2->3->4->5, m=2, n =4 新链表:1->4->3-& ...

  2. 链表逆序(JAVA实现)

    题目:将一个有链表头的单向单链表逆序 分析: 链表为空或只有一个元素直接返回: 设置两个前后相邻的指针p,q,使得p指向的节点为q指向的节点的后继: 重复步骤2,直到q为空: 调整链表头和链表尾: 图 ...

  3. 链表逆序,java实现

    package com.cskaoyan.linkedlist; //反转数组 public class LinkedListDemo2 { public static Node reverse(No ...

  4. C# 单向链表 逆序(递归)

    static void Main(string[] args) { while (true) { LinkedList L = new LinkedList(); L.Add(new Node(&qu ...

  5. 链表逆序---python

    class ListNode: Value = '' # 节点要储存的值,因为Python是弱类型,因此无需传入泛型 Next = None # 下一个节点,初始化时为空值 def __init__( ...

  6. 剑指Offer03 逆序输出链表&链表逆序

    多写了个逆序链表 /************************************************************************* > File Name: ...

  7. 基于visual Studio2013解决面试题之0504单链表逆序

     题目

  8. 【云栖社区001-数据结构】如何实现一个高效的单向链表逆序输出(Java版)

    如题 动手之前,发现自己很擅长用C语言来写链表. 不过,既然自己做的是Java开发,那么还是用Java实现这个算法吧:毕竟,以后的若干年里都差不多要跟Java打交道了. 于是,先将Java版的链表自学 ...

  9. C语言两个升序递增链表逆序合并为一个降序递减链表,并去除重复元素

    #include"stdafx.h" #include<stdlib.h> #define LEN sizeof(struct student) struct stud ...

随机推荐

  1. Ruby中Time的常用函数

      Time的常用函数 时间对象. Time.now返回当前时间. 1.Time.at Time.at(time[, usec]) 返回time所指时间的Time对象. time可以是Time对象,也 ...

  2. SQL2008无法连接到(local),该账户当前被锁定,所以Sa用户登陆失败

    1 安装小结 换了电脑,很多软件都得重装,期间报了很多问题,比如说先装vs2008再装sql server2008r2会报一个“存在2008早期版本”,通过查找,百度一系列的坑爹之路后,我还是把vs2 ...

  3. lazy-mock ,一个生成后端模拟数据的懒人工具

    lazy-mock   lazy-mock 是基于koa2构建的,使用lowdb持久化数据到JSON文件.只需要简单的配置就可以实现和json-server差不多的功能,但是比json-server更 ...

  4. MFC数据库操作

    本例采用Microsoft SQL2008建立的一个数据库表 /****链接数据库操作**/ 在stdafx.h的头文件中加入 #import "C:\Program Files\Commo ...

  5. NSLayoutConstraint 遍历查找对应的约束

      当我们使用纯代码方式Autolayout进行布局约束时,一个view上可能添加了很多的约束.而这些约束又不像view一样有一个可以区分的tag值,茫茫约束中想查到想要的约束然后进行更改,好像很难. ...

  6. 请整体描述Java异常体系

    java把异常当做对象来处理,并定义一个基类Throwable作为所有异常的超类.在java API中已经定义了许多异常的类,这些异常分为两大类,错误Error和异常Exception.其中异常Exc ...

  7. mysql,存储引擎,事务,锁,慢查询,执行计划分析,sql优化

    基础篇:MySql架构与存储引擎 逻辑架构图: 连接层: mysql启动后(可以把mysql类比为一个后台的服务器),等待客户端请求,当请求到来后,mysql建立一个一个线程处理(线程池则分配一个空线 ...

  8. django 数据库 ORM创建表单是出错

    WARNINGS: ?: (mysql.W002) MySQL Strict Mode is not set for database connection 'default' HINT: MySQL ...

  9. SQL索引的优缺点

    --索引的优点 /* (1)创建唯一索引,保证数据库表中每一行数据的唯一性 (2)大大加速数据的检索速度,这也是创建索引的最主要的原因 (3)加速表和表至今的连接,特别是在实现数据的参考完整性特别有意 ...

  10. js时间与毫秒数互相转换(转)

    [1]js毫秒时间转换成日期时间   var oldTime = (new Date("2017/04/25 19:44:11")).getTime(); //得到毫秒数    / ...