【剑指 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;
}
}
这两种方法各有优劣,三指针法在空间复杂度上更优,而头插法则更简洁易懂。读者可以根据具体需求选择合适的方法。
热门推荐
格力天花机E9故障怎么办?原因分析与解决指南
菌菇口蘑牛尾汤:冬季滋补,暖心暖胃
智能工地扬尘监测系统:打造绿色施工环境的关键技术
如何筛选有效数据库
明朝皇帝的一日生活:时间安排与日常仪式
防暑必除湿,这几个穴位解决头晕脸肿肩颈痛
《知然岛》:一部探讨AI与人类关系的科幻力作
梦见黑狗:文化内涵与心理解读
中耳胆脂瘤:不是真肿瘤,危害却不小!
网购90%羊绒大衣实为聚酯纤维?法院判三倍赔偿
小学数学:分数的初步认识及应用
假分数比真分数大吗
核电池如何点亮未来?
腹部疼痛、饱胀、恶心,小心胃息肉,及时治疗,做好5个预防
儿童发育迟缓的警示信号
养鹦鹉也能摊上事?国家新规出台,养错品种可能面临判刑罚款!
崩坏星穹铁道:刃的终极毕业装备与炫酷技能全览
什么叫核心股?核心股有哪些判断标准?
驾驶证到期了怎样进行续期操作?续期时需要准备哪些材料?
家人们速看!超绝烟熏牛肉腌制法,美味直冲天灵盖
关于判后答疑,你需要了解这些
关于判后答疑,你了解多少?
科学和AI如何融合发展,这个机构发布十大前沿方向
国家企业信用信息公示系统使用指南:从注册到信息查询全攻略
深入理解调制传递函数(MTF)及其在光学成像质量评估中的关键作用
伦理经营:企业可持续发展的核心价值所在
企业环境责任包括哪些内容
中古包购买避坑攻略:价格、瑕疵、网购注意事项!新手必看!
郭淮:三国时期曹魏名将,曾阻止诸葛亮北伐,料敌精准
狗牙根作为饲料的经济效益