码迷,mamicode.com
首页 > 其他好文 > 详细

92. Reverse Linked List II

时间:2018-06-05 13:31:03      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:out   put   size   lin   等于   nod   solution   color   str   

问题描述:

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

Note: 1 ≤ m ≤ n ≤ length of list.

Example:

Input: 1->2->3->4->5->NULL, m = 2, n = 4
Output: 1->4->3->2->5->NULL

 

解题思路:

这里要求翻转第m个节点到第n个节点的顺序。

我们可以先通过m与n之间的距离(n-m)确定一个滑动窗口:头节点为start,尾节点为end,然后再根据m来找到窗口具体的起始位置

现将块的头尾翻转,即:

start->next = end->next;

pre(头节点的前一个节点)-> next = end

需要注意的是!

边界情况当m等于1时!我们可以吧head直接指到end节点。

代码:

/**
 * 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(!head || (m == n))
            return head;
        ListNode *start = head;
        ListNode *end = head;
        ListNode *p = head;
        int diff = n - m;
        while(diff){
            p = p->next;
            diff--;
        }
        start = head;
        end = p;
        ListNode *pre = start;
        for(int i = 1; i < m; i++){
            pre = start;
            start = start->next;
            end = end->next;
        }
        ListNode* nextN = end->next;
        //start to reverse
        if(m == 1){
            head = end;   
        }else{
            pre->next = end;
        }
        p = start->next;
        pre = start;
        start->next = nextN;
        
        while(p != nextN){
            ListNode* temp = p->next;
            p->next = pre;
            pre = p;
            p = temp;
        }
        return head;
    }
};

 

92. Reverse Linked List II

标签:out   put   size   lin   等于   nod   solution   color   str   

原文地址:https://www.cnblogs.com/yaoyudadudu/p/9139107.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!