LeetCode热题100--206.反转链表--简单

1. 题目

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

示例 1:

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

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

示例 2:

输入:head = [1,2]

输出:[2,1]

示例 3:

输入:head = []

输出:[]

2. 题解

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode pre = null;
        ListNode cur = head;
        while(cur != null){
            ListNode nxt = cur.next;
            cur.next = pre;
            pre = cur;
            cur = nxt;
        }
        return pre;
    }
}

3. 解析

依旧是灵茶山艾府:【视频讲解】反转链表 O(1) 空间写法,附题单(Python/Java/C++/C/Go/JS/Rust)

  1. class Solution { ... } - 定义了一个名为Solution的类。

  2. 2-5. ListNode reverseList(ListNode head) { ... } - 这个方法接受一个参数,即链表的头节点。它返回反转后的链表的新头节点。

  3. 6-10. ListNode pre = null; ListNode cur = head; while (cur != null) {...} - 初始化两个变量:一个用于跟踪前一个节点(pre),另一个用于当前节点(cur)。然后进入循环,只要当前节点不为null就继续执行。

  4. 11-14. ListNode nxt = cur.next; cur.next = pre; pre = cur; cur = nxt; - 在这段代码中,我们首先将下一个节点的引用保存在nxt变量中(因为一旦改变cur.next,就无法获取到原始的下一个节点了)。然后我们"旋转"链表,通过将当前节点的指针指向前一个节点(pre)来实现。然后更新pre和cur以继续处理剩余的列表。

  5. return pre; - 当while循环结束时,cur将是null(因为我们已经遍历了所有元素并到达末尾),而pre成为了原始链表的最后一个节点,也就是反转后的新头节点,所以返回它。

  6. 这段代码的时间复杂度为O(n),其中n是单链表中的节点数,因为我们需要遍历整个列表一次来完成操作。空间复杂度为O(1),因为我们在原地修改指针而没有使用额外的数据结构。

相关推荐
黑屋里的马14 小时前
java的设计模式之桥接模式(Bridge)
java·算法·桥接模式
z1874610300314 小时前
list(带头双向循环链表)
数据结构·c++·链表
sin_hielo14 小时前
leetcode 1611
算法·leetcode
李小白杂货铺14 小时前
识别和破除信息茧房
算法·信息茧房·识别信息茧房·破除信息茧房·算法推荐型茧房·观点过滤型茧房·茧房
来荔枝一大筐15 小时前
C++ LeetCode 力扣刷题 541. 反转字符串 II
c++·算法·leetcode
暴风鱼划水15 小时前
算法题(Python)数组篇 | 6.区间和
python·算法·数组·区间和
zl_vslam16 小时前
SLAM中的非线性优-3D图优化之轴角在Opencv-PNP中的应用(一)
前端·人工智能·算法·计算机视觉·slam se2 非线性优化
是苏浙16 小时前
零基础入门C语言之C语言实现数据结构之顺序表应用
c语言·数据结构·算法
lkbhua莱克瓦2416 小时前
Java基础——常用算法3
java·数据结构·笔记·算法·github·排序算法·学习方法
小白程序员成长日记16 小时前
2025.11.07 力扣每日一题
数据结构·算法·leetcode