Reverse Linked List II 单向链表逆序(部分逆序)
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 单向链表逆序(部分逆序)的更多相关文章
- 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-> ...
- [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-> ...
- lintcode 中等题: reverse linked list II 翻转链表II
题目 翻转链表 II 翻转链表中第m个节点到第n个节点的部分 样例 给出链表1->2->3->4->5->null, m = 2 和n = 4,返回1->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 ...
- [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-> ...
- 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 ...
- [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 ...
- 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 ...
- 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-> ...
随机推荐
- C#webform LinQ
LinQ的高级查询: 模糊查 con.Car.Where(r=>r.Name.Contains(cname)).ToList(); 以..开头 con.car.Where(r => r.n ...
- 纯JS 将table表格导出到excel
html <div > <button type="button" onclick="getXlsFromTbl('tableExcel','myDiv ...
- MDI窗体容器、权限设置
一.MDI窗体容器: 1.功能: 它可以让其它窗体在它的内部打开,无法超出它的范围 将某个窗体的属性:IsMdiContainer设置为true - 窗口样式 2.问题: (1)如何将其它窗体在它的内 ...
- ACCESS导入CSV文件出现乱码解决办法
在ACCESS或Excel中导入CSV文件时常常出现乱码,这是因为简体中文版的windows操作系统及其应用软件默认都是ANSI/GBK编码,而导入的文件使用的编码与操作系统默认的编码不相符.出现这种 ...
- Tableau10.0学习随记-分组问题
1.根据官网的练习视频,分组时可多选列,之后使用回形针按钮创建分组,并重新命名即可,截图如下: 2.但在Tableau10中打开练习工作簿练习时,并没有直接显示分组后结果,仅仅是创建了分组的纬度,结果 ...
- ADO总结测试数据库
create database ADO测试 go use ADO测试 go create table Student ( Code ) not null primary key,--学生编号,主键 N ...
- Msbuild项目集成右键菜单编译
DS1.背景: 我们为什么要将VS2008命令行编译.sln文件集成到右键菜单呢? 原因一:VS2008很好很强大,但太费系统资源了,尤其是在虚拟机在里面装VS2008的时候更是如此. 原因二:有 ...
- Linux 关机命令
正确的关机流程是:sync –> shutdown/reboot/halt/poweroff sync 将数据由内存同步到硬盘中. shutdown 关机指令.例如你可以运行如下命令关机: sh ...
- swift 计算label的行数方法
这主要针对是 cell上label自适应高度, let lineSpaceKey = "lineSpaceKey" extension UILabel{ var lineSpace ...
- js变量及其作用域
Javascript和Java.C这些语言不同,它是一种无类型.弱检测的语言.它对变量的定义并不需要声明变量类型,我们只要通过赋值的形式,可以将各种类型的数据赋值给同一个变量 一.js变量的类型及 ...