206.反转链表
206.反转链表
给你单链表的头结点
head
,请你反转链表,并返回反转后的链表输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
1 ——> 2 输入:head = [1,2]
2 ——> 1 输出:[2,1]
提示:
- 链表中节点的数目范围是
[0,5000]
-5000 <= Node.val <= 5000
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 prev = null;
ListNode curr = head;
while (curr != null) {
ListNode next = curr.next;
curr.next = prev;
prev = curr;
curr = next;
}
return prev;
}
}
解析:
以1,2,3,4,5为例
head
|
头结点 -> 1 -> 2 -> 3 -> 4 -> 5
|
curr
prev = null, curr = head
head
|
头结点 -> 1 -> 2 -> 3 -> 4 -> 5
| |
curr next
prev = null, curr = prev = null ; 这里curr 的next 等于null 把curr 的next 指向了前面的结点
head
|
头结点 <- 1 -> 2 -> 3 -> 4 -> 5
| |
prev curr
这个步骤不断重复
结果:
头结点 <- 1 <- 2 <- 3 <- 4 <- 5
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)