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),因为我们在原地修改指针而没有使用额外的数据结构。

相关推荐
Samson Bruce7 分钟前
【初高中数学】
线性代数·数学·算法·机器学习
redaijufeng7 分钟前
我在C++中深入理解了继承,收获颇丰
java·c++·算法
承渊政道8 分钟前
【MySQL数据库学习】MySQL基本查询(下)
数据库·学习·mysql·leetcode·bash·数据库开发·数据库系统
Ricky05538 分钟前
DEIM :采用改进匹配算法实现快速收敛的DETR(中国25年3月研究)
人工智能·算法·目标跟踪
无限码力9 分钟前
美团研发岗 5月9号笔试真题 - 弹性分桶
算法·美团笔试题·美团研发岗笔试题·美团0509笔试题
J2虾虾10 分钟前
C 语言 sizeof 完全用法指南
c语言·数据结构·算法
阿正的梦工坊15 分钟前
【Rust】03-所有权、移动与复制
开发语言·算法·rust
好评笔记28 分钟前
深度学习面试八股—— GRU(Gated Recurrent Unit)
人工智能·rnn·深度学习·算法·机器学习·gru·校招
搞科研的小刘选手33 分钟前
【智能计算方向专题研讨会】第三届智能计算与数据分析国际学术会议(ICDA 2026)
大数据·算法·机器学习·数据挖掘·数据分析·可视化·计算
量化君也39 分钟前
桥水基金全天候策略拆解,构建中国ETF躺平版策略
大数据·人工智能·python·算法·金融·业界资讯