美文网首页
92. 反转链表 II

92. 反转链表 II

作者: fengup | 来源:发表于2019-08-18 18:16 被阅读0次

思路

对于链表的问题,根据以往的经验一般都是要建一个dummy node,连上原链表的头结点,这样的话就算头结点变动了,我们还可以通过dummy->next来获得新链表的头结点。这道题的要求是只通过一次遍历完成,就拿题目中的例子来说,变换的是2,3,4这三个点,我们需要找到第一个开始变换结点的前一个结点,只要让pre向后走m-1步即可,为啥要减1呢,因为题目中是从1开始计数的,这里只走了1步,就是结点1,用pre指向它。万一是结点1开始变换的怎么办,这就是我们为啥要用dummy结点了,pre也可以指向dummy结点。然后就要开始交换了,由于一次只能交换两个结点,所以我们按如下的交换顺序:

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

我们可以看出来,总共需要n-m步即可,第一步是将结点3放到结点1的后面,第二步将结点4放到结点1的后面。

  • 首先,pre指向结点1,cur指向结点2,然后我们建立一个临时的结点tmp,指向结点3(注意我们用临时变量保存某个结点就是为了首先断开该结点和前面结点之间的联系,这可以当作一个规律记下来)tmp=cur->next
  • 然后我们断开结点2和结点3,将结点2的next连到结点4上,也就是 cur->next = t->next
  • 再把结点3连到结点1的后面结点(即结点2)的前面,即tmp->next = pre->next
  • 最后再将原来的结点1和结点2的连接断开,将结点1连到结点3,即pre->next = tmp。这样我们就完成了将结点3取出,加入结点1的后方。

第二步将结点4取出,加入结点1的后方,也是同样的操作,参考代码如下:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */


struct ListNode* reverseBetween(struct ListNode* head, int m, int n){
    struct ListNode dummy;
    dummy.next=head;
    struct ListNode* pre=&dummy;
        
    for(int i=0;i<m-1;i++){
        pre=pre->next;
    }
        
    struct ListNode* cur=pre->next;
    struct ListNode* tmp;
    for(int i=m;i<n;i++){
        tmp=cur->next;
        cur->next=tmp->next;//cur->next = cur->next->next;
        tmp->next=pre->next;
        pre->next=tmp;
    }
    
    return dummy.next;
}

相关文章

  • LeetCode 92. 反转链表 II

    92. 反转链表 II 反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。 说明: 1 ≤ m ≤ n ≤ ...

  • 每日一题1-反转链表 II

    92. 反转链表 II 反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。 说明:1 ≤ m ≤ n ≤ 链...

  • 2.链表(二)

    题目汇总https://leetcode-cn.com/tag/linked-list/92. 反转链表 II中等...

  • LeetCode 92. 反转链表 II(Reverse Lin

    92. 反转链表 II 切题 一、Clarification特别注意 m == 1 与 m!=1 的情况 m==1...

  • 递归反转链表的一部分

    读完本文,你可以去力扣拿下如下题目: 92.反转链表II[https://leetcode-cn.com/prob...

  • 链表:92.反转链表II

    /** 题目 反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。 说明:1 ≤ m ≤ n ≤ 链表长度。 ...

  • 92. 反转链表 II

    思路 对于链表的问题,根据以往的经验一般都是要建一个dummy node,连上原链表的头结点,这样的话就算头结点变...

  • 92. 反转链表 II

    前插法 这个题目和翻转链表不一样的地方就是它需要考虑的情况很多. pre_node cur_node tmp_node

  • 92.反转链表 II

    反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。说明:1 ≤ m ≤ n ≤ 链表长度。示例:输入: 1-...

  • 92. 反转链表 II

    题目描述 给你单链表的头指针 head 和两个整数 left 和 right ,其中 left <= right ...

网友评论

      本文标题:92. 反转链表 II

      本文链接:https://www.haomeiwen.com/subject/keqdsctx.html