【剑指 Offer】反转链表的两种解法
创作时间:
作者:
@小白创作中心
【剑指 Offer】反转链表的两种解法
引用
CSDN
1.
https://m.blog.csdn.net/m0_67660672/article/details/141144059
链表是计算机科学中常用的一种数据结构,而反转链表则是链表操作中的一个经典问题。本文将详细介绍两种常见的链表反转方法:三指针法和头插法,并通过具体的代码实现帮助读者理解这两种方法的原理和应用。
问题描述
给定一个单链表的头结点 pHead(该头节点是有值的,比如在下图,它的 val 是 1),长度为 n,反转该链表后,返回新链表的表头。
解题思路
反转链表有多种解法,这里介绍两种常见的方法:
- 定义三个指针,整体右移,边移动边翻转,保证不会断链。
- 采用头插思想进行翻转。
方法一:三指针法
这种方法通过三个指针 first、second 和 third 来实现链表的反转。具体步骤如下:
- 初始化三个指针分别指向链表的第一个、第二个和第三个节点。
- 在循环中,将
second指针指向的节点的next指针指向first,实现局部反转。 - 然后将三个指针整体后移一位。
- 当
third指针为null时,说明已经到达链表尾部,此时需要处理最后两个节点的反转关系,并将原链表头节点的next指针置为null。
以下是具体的代码实现:
public class Solution {
public ListNode ReverseList(ListNode head) {
if (head == null || head.next == null) {
return head;
}
// 不带头结点,至少有2个节点
ListNode first = head; // 指向第一个节点
ListNode second = first.next; // 指向第二个节点
ListNode third = second.next; // 指向第三个节点,可能为null
while (third != null) {
// 翻转
second.next = first;
// 指针整体后移
first = second;
second = third;
third = third.next;
}
second.next = first; // 当传入的链表只有两个节点 or 上述翻转结束时,最后一个节点并未翻转
head.next = null; // 曾经的第一个节点,next并不是null,设置一下
head = second; // 头指针指向最后一个节点
return head;
}
}
方法二:头插法
这种方法通过一个新链表 new_head 来实现链表的反转。具体步骤如下:
- 初始化一个空的新链表头节点
new_head。 - 在循环中,每次从原链表中取出第一个节点,并将其插入到新链表的头部。
- 重复上述过程,直到原链表为空。
以下是具体的代码实现:
public class Solution {
public ListNode ReverseList(ListNode head) {
if (head == null || head.next == null) {
return head;
}
ListNode new_head = null;
while (head != null) {
// 先从原链表中去掉第一个节点
ListNode p = head;
head = head.next;
// 再将p标识的节点头查到新链表
p.next = new_head;
new_head = p;
}
head = new_head;
return head;
}
}
这两种方法各有优劣,三指针法在空间复杂度上更优,而头插法则更简洁易懂。读者可以根据具体需求选择合适的方法。
热门推荐
厌奶期的表现和怎么解决
怎样睡觉才能不打呼噜
心理健康:五种情绪纾解的方法
如何面对逆境?
如何分析房地产行业的财务结构?房地产行业有哪些关键指标?
项目管理绩效报告撰写指南:从时间到风险管理的全面解析
热浪来袭时保护植物的小贴士
密歇根大学发布Chumor 2.0:首个大规模中文幽默理解数据集
聚焦校园外卖热点,探寻平台搭建的新思路与新方法
摆动分析之MACD(平滑移动平均线)
我们从何而来,未来又要往何处去?丨人类起源的奥秘(深度好文)
韩国再推“室温超导”新材料,国内团队:两个月前就知道PPT内容了
濒死到底是怎样的?濒死的感觉
骁龙845相当于天玑多少?从跑分数据看两款处理器性能对比
「GIS资源」分享下中国历史地图在线服务(WMTS版)
重度抑郁症怎么转移注意力
仿生人是人工智能吗
英国欠款不还,中国起诉追讨:涉外债务追讨的法律实践与策略
如何阻止微信小程序自动打开?
《底特律:化身为人》:互动式电影游戏里程碑
休闲难度 VS 经验难度:在《底特律:成为人类》中该选择哪一个?
影响孩子社交态度的重要因素
摩托车过户可以委托他人办理吗
股市风向标 | 芯片竞争加剧 AMD目标股价被下调
上海户口离婚无房户口怎么落
天秤座与处女座的和谐配对:星座间的微妙平衡
如何应对低保减少的情况?这种情况有什么解决办法?
艾滋病与流感症状:辨识关键差异,守护健康防线
甘肃气候类型:从亚热带季风到高原高寒
【普法课堂】儿子给母亲打借条,儿媳未签字,是否有还款义务?