一起学习LeetCode热题100道(23/100)

23.反转链表(学习)

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

示例 1:

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

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

示例 2:

输入:head = [1,2]

输出:[2,1]

示例 3:

输入:head = []

输出:[]

提示:

链表中节点的数目范围是 [0, 5000]

-5000 <= Node.val <= 5000

解析:

一、初始化指针:

1.prev 指针:用于跟踪当前节点的前一个节点,初始时设置为 null,因为反转后的链表的头节点前面没有节点。

2.curr 指针:用于遍历原始链表,初始时设置为链表的头节点 head。

二、迭代遍历链表:

1.在每次迭代中,首先保存 curr 节点的下一个节点到 nextTemp 变量中,以防丢失。

2.然后,将 curr 节点的 next 指针指向 prev,这样就完成了当前节点的反转。

3.接着,将 prev 和 curr 都向前移动一位。具体来说,prev 变成当前的 curr,而 curr 变成之前保存的 nextTemp。

三、返回新的头节点:

1.当 curr 变为 null 时,说明已经遍历完了整个链表,此时 prev 指针将指向新的头节点(即原链表的尾节点)。

2.返回 prev 指针作为反转后链表的头节点。

javascript 复制代码
var reverseList = function(head) {
    let prev = null; // 前一个节点,初始化为null  
    let curr = head; // 当前节点,初始化为头节点  
  
    while (curr !== null) {  
        let nextTemp = curr.next; // 临时保存当前节点的下一个节点  
        curr.next = prev; // 将当前节点的next指针指向前一个节点,实现反转  
        prev = curr; // 前一个节点前进到当前节点  
        curr = nextTemp; // 当前节点前进到原来的下一个节点  
    }  
  
    return prev; // 当循环结束时,prev将会是新的头节点
};
相关推荐
_feivirus_12 分钟前
神经网络_使用TensorFlow预测气温
人工智能·神经网络·算法·tensorflow·预测气温
大柏怎么被偷了22 分钟前
【C++算法】位运算
开发语言·c++·算法
sixteenyy23 分钟前
学习笔记(一)
笔记·学习
程序猿方梓燚24 分钟前
C/C++实现植物大战僵尸(PVZ)(打地鼠版)
c语言·开发语言·c++·算法·游戏
CPP_ZhouXuyang24 分钟前
C语言——模拟实现strcpy
c语言·开发语言·数据结构·算法·程序员创富
闻缺陷则喜何志丹25 分钟前
【C++前后缀分解 动态规划】2100. 适合野炊的日子|1702
c++·算法·动态规划·力扣·前后缀分解·日子·适合
逝去的秋风38 分钟前
【代码随想录训练营第42期 Day57打卡 - 图论Part7 - Prim算法与Kruskal算法
算法·图论·prim算法
QXH2000001 小时前
数据结构—双向链表
c语言·数据结构·算法·链表
旺小仔.1 小时前
【数据结构篇】~排序(1)之插入排序
c语言·数据结构·算法·链表·性能优化·排序算法
计算机学姐1 小时前
基于python+django+vue的在线学习资源推送系统
开发语言·vue.js·python·学习·django·pip·web3.py