Leetcode: 92. Reverse Linked List II

Description

Reverse a linked list from position m to n. Do it in-place and in one-pass.code

Example

Given 1->2->3->4->5->NULL, m = 2 and n = 4,

return 1->4->3->2->5->NULL.

Note:

Given m, n satisfy the following condition:
1 ≤ m ≤ n ≤ length of list.

思路

  • 先找到m的位置,記錄它的前一個pre,而後在[m,n]之間逆轉鏈表,記錄逆轉後的鏈表尾tail,和鏈表頭cur。最後把逆轉後的鏈表接到原鏈表合適位置

代碼

/**
 * 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) {
        ListNode *pre = NULL, *ptr = head;
        ListNode *res = NULL;
        ListNode *cur = NULL, *tail = NULL;
        ListNode *tmp = NULL;
        
        int k = 1;
        while(k < m){
            pre = ptr;
            if(res == NULL)
                res = pre;
            ptr = ptr->next;
            k++;
        }
        
        while(k <= n){
            tmp = ptr->next;
            if(cur == NULL){
                cur = ptr;
                tail = ptr;
            }
            else{
                ptr->next = cur;
                cur = ptr;
            }
            ptr = tmp;
            k++;
        }
        
        if(res == NULL){
            res = cur;
        }
        else pre->next = cur;
        
        tail->next = ptr;
        
        return res;    
    }
};
相關文章
相關標籤/搜索