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

92.反转链表 II

作者: 衣锦昼行 | 来源:发表于2019-08-07 15:30 被阅读0次

反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。
说明:
1 ≤ m ≤ n ≤ 链表长度。
示例:
输入: 1->2->3->4->5->NULL, m = 2, n = 4
输出: 1->4->3->2->5->NULL

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode reverseBetween(ListNode head, int m, int n) {
        int len = 0;
        ListNode node = head;
        ListNode fPre = null;
        ListNode tPos = null;
        while (node!=null){
            len++;
            fPre = (len == m-1) ? node : fPre;
            tPos = (len == n+1) ? node : tPos;
            node = node.next;
        }
        if(m < 1 || n > len)
            return head;
        node = fPre == null ? head : fPre.next;
        ListNode node1 = node.next;
        node.next = tPos;
        ListNode next = null;
        while (node1 != tPos){
            next =node1.next;
            node1.next = node;
            node = node1;
            node1 = next;
        }
        if(fPre != null){
            fPre.next = node;
            return head;
        }
        return node;
    }
}

复杂度分析:
时间复杂度:O(N)
空间复杂度:O(N)

相关文章

  • 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/otoodctx.html