0 问题描述

原题点击这里。

将单向链表第m个位置到第n个位置倒序连接。例如,

原链表:1->2->3->4->5, m=2, n =4

新链表:1->4->3->2->1

(注:最终的新链表记为head,过程中临时使用的一个链表头记为h)

1 基本思路

首先考虑整个链表的情况。见到单向链表的第一反应自然是轮询链表head中每个节点,轮询过程中按需要建立一个新链表h,每次访问一个节点,就将这个节点放在前一个访问的节点之后,这样便实现了倒序。

然后再考虑部分倒序。要部分倒序,便要找出这部分从哪里开始,从哪里结束,根据前面的方法将该部分倒序之后,将倒序后的部分链表链上其他部分。

2 单向链表逆序

假设有三个节点,其过程如图(1)所示。

第一步取出node1,新链头指向node1,node1->next指向空,其他部分不变;

第二步取出node2,新链头指向node2,node2->next指向前一个访问的节点(即node1);

第二步取出node3,新链头指向node3,node3->next指向前一个访问的节点(即node2);

从这个过程中可以看到几点:

这是一个循环过程。循环的次数=链表中节点的个数。

每个节点都访问了且只访问一次,因而时间复杂度是O(n)。

需要三个辅助变量。1、使用了一个临时链头h;2、观察第二步(图1-2),该步将node2->next指向了node1,因此需要使用变量(prev)将node1保存下来。3、同样观察第二步,该步中将node2和node3之间的联系断开了,但是在下一次操作中需要使用到node3,因此需要使用变量(next)将node3保存下来。

这部分也就是该问题的核心代码。

while (len--) {
next = p->next;
h = p;
h->next = prev;
prev = p;
p = next;
}

3 部分逆序

假设现在有五个节点,我们需要将节点1-3倒序。首先将1-3倒序,那么现在该如何将节点0、4和完成倒序后的链表连接起来?结合图容易想到,node0->next应指向node3;node1->next应指向node4(见图2-2)。

node0->next指向node3只需要将新链表头h赋给它;

node1->next指向node4需要在上一节第一步中将它指向node4.

图示采用的是一个特例,在一般情况下,我们需要找到pa->next连接新链表头h的pa,以及新链表尾部->next指向的pb(见图2-3)。寻找很简单,但必须要考虑特殊情况:如果m=1,即h就是我们最后需要得到的链表头head.

  

  

4 源代码

  ReverseLinkedListII.c Github

Reverse Linked List II 单向链表逆序(部分逆序)的更多相关文章

  1. leetcode——Reverse Linked List II 选择链表中部分节点逆序(AC)

    Reverse a linked list from position m to n. Do it in-place and in one-pass. For example: Given 1-> ...

  2. [LeetCode] Reverse Linked List II 倒置链表之二

    Reverse a linked list from position m to n. Do it in-place and in one-pass. For example:Given 1-> ...

  3. lintcode 中等题: reverse linked list II 翻转链表II

    题目 翻转链表 II 翻转链表中第m个节点到第n个节点的部分 样例 给出链表1->2->3->4->5->null, m = 2 和n = 4,返回1->4-> ...

  4. [LeetCode] 92. Reverse Linked List II 倒置链表之二

    Reverse a linked list from position m to n. Do it in one-pass. Note: 1 ≤ m ≤ n ≤ length of list. Exa ...

  5. [LeetCode] 92. Reverse Linked List II 反向链表II

    Reverse a linked list from position m to n. Do it in-place and in one-pass. For example:Given 1-> ...

  6. LeetCode 92. Reverse Linked List II倒置链表2 C++

    Reverse a linked list from position m to n. Do it in one-pass. Note: 1 ≤ m ≤ n ≤ length of list. Exa ...

  7. [leetcode]92. Reverse Linked List II反转链表2

    Reverse a linked list from position m to n. Do it in one-pass. Note: 1 ≤ m ≤ n ≤ length of list. Exa ...

  8. 92. Reverse Linked List II 翻转链表II

    Reverse a linked list from position m to n. Do it in one-pass. Note: 1 ≤ m ≤ n ≤ length of list. Exa ...

  9. 92. Reverse Linked List II(链表部分反转)

    Reverse a linked list from position m to n. Do it in-place and in one-pass. For example:Given 1-> ...

随机推荐

  1. 无线OSS-高精度整数加法

    #include<iostream> #include<string> using namespace std; int compareStr(string str1, str ...

  2. Java内存模型

    1. 概述 多任务和高并发是衡量一台计算机处理器的能力重要指标之一.一般衡量一个服务器性能的高低好坏,使用每秒事务处理数(Transactions Per Second,TPS)这个指标比较能说明问题 ...

  3. 关于磁盘错误disk error

    到同事办公室的时候,机器的启动界面就停在磁盘错误disk error上. 首先怀疑的就是硬盘可能坏了,于是就用u盘启动,运行mhdd检测,一直到10%都没有发现错误.于是退出,重启,发现机器能够启动x ...

  4. 【翻译】configuration changes与handler.post

    原文地址 http://corner.squareup.com/2013/12/android-main-thread-2.html 在前一部分里面previous part ,我们深入挖掘了 loo ...

  5. windows下登录lunix服务器

    在微信项目中,负责发布,我就把我用到的记录一下.有两种登录方式,看你要做什么操作. 1.SecureCRT 支持命令行操作.(主要是发布程序) 调试.微信公众号规定要有服务器的网址,一般公司的都是内网 ...

  6. scala 打印一个乘法口诀表 (<<scala 编程>> P87)

    (for(i <- 1 to 9;j <- 1 to i; s = s"$j*$i=${i*j}\t") yield {if(j==1) s"$s\n&quo ...

  7. 获取数据库表详细信息、存储过程、视图、的sql

    select s.[name] + '.' + t.[name] as tablename from sys.tables as t,sys.schemas as s where t.schema_i ...

  8. web学习之servlet

    1)web服务软件作用: 把本地资源共享给外部访问 2)tomcat服务器基本操作 : 启动:  %tomcat%/bin/startup.bat 关闭: %tomcat%/bin/shutdown. ...

  9. Making the Newsfeed web part available outside of My Sites in SharePoint 2013 分类: Sharepoint 2015-07-07 19:29 4人阅读 评论(0) 收藏

    The Newsfeed is a key piece in SP2013's approach to social computing. It appears on the landing page ...

  10. 关于SQL安装问题及安装前的准备

    转载自:IceWee  原文连接:http://www.cnblogs.com/icewee/articles/2019783.html 由于工作需要,今天要在电脑上安装SQL Server 2005 ...