力扣206.反转链表 92.反转链表II

LeetCode 206. 反转链表(简单)

题目:反转一个单链表。

示例

复制代码
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL

解法一:迭代(双指针)

cpp 复制代码
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        ListNode* prev = nullptr;
        ListNode* curr = head;
        while (curr) {
            ListNode* next = curr->next;
            curr->next = prev;
            prev = curr;
            curr = next;
        }
        return prev;
    }
};

解法二:递归

cpp 复制代码
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        if (!head || !head->next) return head;
        ListNode* newHead = reverseList(head->next);
        head->next->next = head;
        head->next = nullptr;
        return newHead;
    }
};

LeetCode 92. 反转链表 II(中等)

题目 :反转从位置 leftright 的链表节点(索引从 1 开始)。

示例

复制代码
输入: 1->2->3->4->5->NULL, left = 2, right = 4
输出: 1->4->3->2->5->NULL

解法:一次遍历 + 局部反转

思路

  1. 找到待反转部分的前一个节点 pre 和起始节点 start
  2. 反转 [left, right] 区间内的节点,记录反转后的头尾。
  3. pre 连接到反转后的头,反转后的尾连接到后续节点。
cpp 复制代码
class Solution {
public:
    ListNode* reverseBetween(ListNode* head, int left, int right) {
        if (!head || left == right) return head;
        
        ListNode dummy(0);
        dummy.next = head;
        ListNode* pre = &dummy;
        
        // 1. 移动 pre 到 left 的前一个节点
        for (int i = 1; i < left; ++i) {
            pre = pre->next;
        }
        
        // 2. 反转 [left, right] 区间
        ListNode* curr = pre->next;
        ListNode* prev = nullptr;
        for (int i = left; i <= right; ++i) {
            ListNode* next = curr->next;
            curr->next = prev;
            prev = curr;
            curr = next;
        }
        
        // 3. 连接
        pre->next->next = curr;  // 原 left 节点的 next 指向 right 后面的节点
        pre->next = prev;        // pre 指向反转后的头节点
        
        return dummy.next;
    }
};

复杂度

  • 时间:O(n)
  • 空间:O(1)
相关推荐
超级码力66639 分钟前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind1 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师2 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F4 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业5 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn5 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室6 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星6 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿7 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算