当前位置: 首页 > ai >正文

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. 题解

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

http://www.xdnf.cn/news/5962.html

相关文章:

  • 捌拾肆- 量子傅里叶变换 (2)
  • 编译docker版openresty
  • MySQL——数据类型表的约束
  • 无线定位之四 SX1302 网关源码 thread_jit 线程详解
  • 道通EVO MAX系列无人机-支持二次开发
  • Springboot实现重试机制
  • 工具学习_VirusTotal使用
  • 集成钉钉消息推送功能
  • 软件I2C
  • python3:文件与异常
  • JSON 和 cJSON 库入门教程
  • SPI接口:原理;从设备slave如何主动给主设备master发数据?
  • 基于MNIST数据集的手写数字识别(简单全连接网络)
  • 共享代理IP带宽受限影响大吗
  • SQL:MySQL函数:数学函数(Mathematical Functions)
  • 牛客周赛96补题 D F
  • 【IC验证】systemverilog_类
  • yum安装-此系统没有注册
  • Python打包工具PyInstaller,打包之后的反编译工具pyinstxtractor
  • 2025.05.10京东机考真题算法岗-第一题
  • QT 插槽实现
  • 最短路与拓扑(1)
  • openjdk底层汇编指令调用(三)——编码
  • Ensemble Alignment Subspace Adaptation Method for Cross-Scene Classification
  • HDFS的客户端操作(1)
  • USB3.0拓展坞制作学习
  • Linux系统编程---Signal信号集
  • Profibus DP主站转Modbus RTU/TCP如何把E+H流量计接入到modbus
  • 基于单片机的视力保护仪设计与实现
  • 硬密封保温 V 型球阀:恒温工况下复杂介质控制的性价比之选-耀圣