力扣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)
相关推荐
澈2072 小时前
哈希表实战:从原理到手写实现
算法·哈希算法
旖-旎2 小时前
哈希表(存在重复元素||)(4)
数据结构·c++·算法·leetcode·哈希算法·散列表
Run_Teenage2 小时前
Linux:认识信号,理解信号的产生和处理
linux·运维·算法
無限進步D3 小时前
蓝桥杯赛前刷题
c++·算法·蓝桥杯·竞赛
CoderCodingNo3 小时前
【GESP】C++二级真题 luogu-B4497, [GESP202603 二级] 数数
开发语言·c++·算法
磊 子3 小时前
八大排序之冒泡排序+选择排序
数据结构·算法·排序算法
_深海凉_3 小时前
LeetCode热题100-买卖股票的最佳时机
leetcode
We་ct3 小时前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
潇洒畅想3 小时前
1.1 从∑到∫:用循环理解求和与累积
java·数据结构·python·算法