[链表] - 代码随想录 206. 反转链表

[链表] - 代码随想录 206. 反转链表

题目要求

反转一个单链表。

实现代码

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 cur = head;  // 当前遍历节点
        ListNode pre = null;  // 前驱节点 (反转后将成为后继)
        while (cur != null) {
            ListNode next = cur.next; // 暂存后继节点
            cur.next = pre;    // 反转指针:当前节点指向前驱
            pre = cur;         // 前驱节点后移
            cur = next;        // 当前节点后移
        }
        return pre; // 循环结束时,pre指向新链表的头节点
    }
}

算法说明

该实现采用迭代法反转链表,核心步骤如下:

  1. 初始化指针

    • cur 指向当前待处理节点(初始为头节点 head)。
    • pre 指向 cur 的前驱节点(初始为 null,表示链表开头)。
  2. 遍历与反转

    • 循环遍历链表,直至 curnull
    • 在每次循环中:
      • 暂存 cur 的下一个节点 (next)。
      • cur.next 指向 pre(完成当前节点的反转)。
      • pre 移动到 cur 位置(更新前驱节点)。
      • cur 移动到暂存的 next 位置(移动到下一个待处理节点)。
  3. 返回结果

    • 循环结束时,curnullpre 指向原链表的最后一个节点,即反转后新链表的头节点,返回 pre

关键点 :通过暂存 next 节点,确保在修改 cur.next 指向 pre 后,仍能找到链表的下一个节点继续遍历。

相关推荐
计算机安禾16 小时前
【C语言程序设计】第34篇:文件的概念与文件指针
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
会编程的土豆16 小时前
【数据结构与算法】 二叉树做题
开发语言·数据结构·c++·算法
leaves falling17 小时前
数据结构-堆学习
java·数据结构·学习
Fcy64817 小时前
算法竞赛有关数据结构的补充(2)--- 栈、队列的静态实现和树的实现
数据结构···队列
Book思议-17 小时前
【数据结构实战】链表找环入口的经典问题:快慢指针法
c语言·数据结构·算法·链表
我能坚持多久17 小时前
【初阶数据结构11】——链式二叉树知识补充
数据结构·算法
liuyao_xianhui18 小时前
优选算法_两数之和_位运算_C++
java·开发语言·数据结构·c++·算法·链表·动态规划
童话ing18 小时前
【Golang】Golang Map数据结构底层原理
数据结构·golang·哈希算法
wWYy.18 小时前
左值引用和右值引用
数据结构
Book思议-18 小时前
【数据结构实战】判断链表是否有环:快慢指针法(Floyd 判圈算法)
c语言·数据结构·算法·链表