力扣: 反转链表

文章目录

需求

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例1:

输入:head = [1,2,3,4,5]

输出:[5,4,3,2,1]

示例2:

输入:head = [1,2]

输出:[2,1]
示例 3:

输入:head = []

输出:[]

分析

初始化:我们使用两个指针,prev 和 current。prev 用来指向反转后的链表的前一个节点(初始时为 None),current 用来遍历原链表(初始时为 head)。

遍历链表:

  • 先保存当前节点的下一个节点 next_node。
  • 将当前节点的 next 指针指向 prev,实现反转操作。
  • 更新 prev 为当前节点。
  • 更新 current 为 next_node,继续遍历。

返回新头节点:当 current 变为 None 时,prev 就是新链表的头节点,返回它即可。

双指针法

java 复制代码
public ListNode reverseList(ListNode head) {
    if( head == null || head.next == null ){
        return head;
    }
    ListNode pre = null;
    ListNode cur = head;
    while( cur != null ){
        //  先把cur的下一个节点拿出来
        ListNode nextNode = cur.next;
        //  将 cur 的下一个指向前一个
        cur.next = pre;
        pre = cur;
        cur = nextNode;
    }   
    return pre;
}

执行结果:

递归

上面的代码很容易改写为递归的写法:

java 复制代码
if( head == null || head.next == null ){
        return head;
    }
    return reverseList( null, head );
}

private ListNode reverseList(ListNode pre, ListNode cur) {
    if( cur == null ){
        return pre;
    }
    //  拿出cur的下一个
    ListNode nextNode = cur.next;
    cur.next = pre;
    return reverseList( cur, nextNode );
}

递归终止条件:

if (cur == null):当遍历到链表的末尾时(即 cur 为 null),返回 pre,这是反转后新链表的头节点。

反转节点:

ListNode nextNode = cur.next;:保存当前节点的下一个节点,以便后续操作。

cur.next = pre;:将当前节点的 next 指针指向前一个节点 pre,这一步是反转指针的核心操作。

递归调用:

return reverseList(cur, nextNode);:调用自身,传入当前节点 cur 作为新的前一个节点,和保存的 nextNode 作为当前节点,以继续反转剩余的链表。

运行结果:

结尾

以上 是我对这道算法的一些遐想和延伸, 可能不是最优解, 但是算法的优化嘛 本身就是一个思索的过程, 能在这个思索和迭代的过程中有所收获和乐趣就是在成长了, 欢迎大家一起来交流更多的解答...

相关推荐
生锈的键盘7 分钟前
推荐算法实践:movielens数据集
算法
董董灿是个攻城狮8 分钟前
Transformer 通关秘籍9:词向量的数值实际上是特征
算法
林泽毅17 分钟前
SwanLab x EasyR1:多模态LLM强化学习后训练组合拳,让模型进化更高效
算法·llm·强化学习
小林熬夜学编程19 分钟前
【高并发内存池】第八弹---脱离new的定长内存池与多线程malloc测试
c语言·开发语言·数据结构·c++·算法·哈希算法
刚入门的大一新生25 分钟前
归并排序延伸-非递归版本
算法·排序算法
独好紫罗兰30 分钟前
洛谷题单3-P1980 [NOIP 2013 普及组] 计数问题-python-流程图重构
开发语言·python·算法
独好紫罗兰35 分钟前
洛谷题单3-P1009 [NOIP 1998 普及组] 阶乘之和-python-流程图重构
开发语言·python·算法
曦月逸霜1 小时前
蓝桥杯高频考点——高精度(含C++源码)
c++·算法·蓝桥杯
ゞ 正在缓冲99%…1 小时前
leetcode152.乘积最大子数组
数据结构·算法·leetcode
闯闯爱编程2 小时前
数组与特殊压缩矩阵
数据结构·算法·矩阵