首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Leetcode 92. Reverse Linked List II

版权声明:博客文章都是作者辛苦整理的,转载请注明出处,谢谢! https://cloud.tencent.com/developer/article/1433933

文章作者:Tyan

博客:noahsnail.com | CSDN | 简书

1. Description

2. Solution

代码语言:javascript
复制
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* reverseBetween(ListNode* head, int m, int n) {
        if(m == n) {
            return head;
        }
        ListNode* start = nullptr;
        ListNode* end = nullptr;
        ListNode* left = nullptr;
        ListNode* right = nullptr;

        ListNode* pre = nullptr;
        ListNode* current = head;
        ListNode* next = nullptr;
        int diff = n - m + 1;
        m--;
        while(m) {
            pre = current;
            current = current->next;
            m--;
        }
        start = pre;
        right = current;
        while(diff) {
            next = current->next;
            current->next = pre;
            pre = current;
            current = next;
            diff--;
        }
        left = pre;
        end = current;
        right->next = end;
        if(start) {
            start->next = left;
            return head;
        }
        else {
            return left;
        } 
    }
};

Reference

  1. https://leetcode.com/problems/reverse-linked-list-ii/description/
下一篇
举报
领券