LeetCode:反转链表II_92
本文最后更新于 1284 天前,其中的信息可能已经有所发展或是发生改变。

思路

这种题就很烦,你说它难吧,它就是在反转链表_206的基础上增加了个数量限制。你说它不难吧,边界问题折磨死你。提交几次,调试半天才AC。

题目

给你单链表的头指针 head 和两个整数 leftright ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表

示例 1:

输入:head = [1,2,3,4,5], left = 2, right = 4
输出:[1,4,3,2,5]

示例 2:

输入:head = [5], left = 1, right = 1
输出:[5]

提示:

  • 链表中节点数目为 n
  • 1 <= n <= 500
  • -500 <= Node.val <= 500
  • 1 <= left <= right <= n

进阶: 你可以使用一趟扫描完成反转吗?

Related Topics
  • 链表
  • 👍 1036
  • 👎 0
  • 代码

            public ListNode reverseBetween(ListNode head, int left, int right) {
                if (head == null) {
                    return null;
                }
    
                // 虚拟头结点
                final ListNode dummy = new ListNode(-1, head);
                ListNode curr = dummy;
    
                // 前进left,这段不用反转
                for (int i = 0; i < left - 1; i++) {
                    curr = curr.next;
                    if (curr == null) {
                        return head;
                    }
                }
    
                // 反转数量为right - left + 1的节点
                curr.next = reverse(curr.next, right - left + 1);
    
                return dummy.next;
            }
    
            private ListNode reverse(ListNode head, int size) {
                if (head == null || size == 0) {
                    return head;
                }
                ListNode curr = head;
                ListNode pre = null;
    
                // 开始反转,增加了个数量限制
                do {
                    ListNode next = curr.next;
                    curr.next = pre;
                    pre = curr;
                    curr = next;
                    size--;
                } while (curr != null && size > 0);
    
                // right后的节点接到反转区间的头结点
                if (curr != null) {
                    head.next = curr;
                }
    
                return pre;
            }
    作者:Yuyy
    博客:https://yuyy.info
    暂无评论

    发送评论 编辑评论

    
    				
    |´・ω・)ノ
    ヾ(≧∇≦*)ゝ
    (☆ω☆)
    (╯‵□′)╯︵┴─┴
     ̄﹃ ̄
    (/ω\)
    ∠( ᐛ 」∠)_
    (๑•̀ㅁ•́ฅ)
    →_→
    ୧(๑•̀⌄•́๑)૭
    ٩(ˊᗜˋ*)و
    (ノ°ο°)ノ
    (´இ皿இ`)
    ⌇●﹏●⌇
    (ฅ´ω`ฅ)
    (╯°A°)╯︵○○○
    φ( ̄∇ ̄o)
    ヾ(´・ ・`。)ノ"
    ( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
    (ó﹏ò。)
    Σ(っ °Д °;)っ
    ( ,,´・ω・)ノ"(´っω・`。)
    ╮(╯▽╰)╭
    o(*////▽////*)q
    >﹏<
    ( ๑´•ω•) "(ㆆᴗㆆ)
    😂
    😀
    😅
    😊
    🙂
    🙃
    😌
    😍
    😘
    😜
    😝
    😏
    😒
    🙄
    😳
    😡
    😔
    😫
    😱
    😭
    💩
    👻
    🙌
    🖕
    👍
    👫
    👬
    👭
    🌚
    🌝
    🙈
    💊
    😶
    🙏
    🍦
    🍉
    😣
    Source: github.com/k4yt3x/flowerhd
    颜文字
    Emoji
    小恐龙
    花!
    上一篇
    下一篇