[链表] - 代码随想录 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 后,仍能找到链表的下一个节点继续遍历。

相关推荐
念越3 小时前
数据结构:栈堆
java·开发语言·数据结构
dear_bi_MyOnly4 小时前
【多线程——线程状态与安全】
java·开发语言·数据结构·后端·中间件·java-ee·intellij-idea
浪客灿心4 小时前
list_stack_queue
数据结构·list
zh_xuan4 小时前
最小跳跃次数
数据结构·算法
zh_xuan4 小时前
单青蛙跳台阶
数据结构·算法
罗湖老棍子5 小时前
【 例 1】石子合并(信息学奥赛一本通- P1569)
数据结构·算法·区间dp·区间动态规划·分割合并
小高Baby@6 小时前
JSON、bind、form
数据结构·json
TracyCoder1237 小时前
LeetCode Hot100(21/100)——234. 回文链表
算法·leetcode·链表
数智工坊8 小时前
【数据结构-栈】3.1栈的顺序存储-链式存储
java·开发语言·数据结构
执着2599 小时前
力扣102、二叉树的层序遍历
数据结构·算法·leetcode