zoukankan      html  css  js  c++  java
  • Leetcode练习(Python):链表类:第92题:反转链表 II:反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。

    题目:
    反转链表 II:反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。

    反转从位置 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.
    # class ListNode:
    #     def __init__(self, x):
    #         self.val = x
    #         self.next = None

    class Solution:
        def reverseBetween(self, head: ListNode, m: int, n: int) -> ListNode:
            if not head:
                return head
            if m >= n:
                return head
            myNode = ListNode(0)
            myNode.next = head
            index1 = myNode
            num_rotate = n - m
            while m - 1:
                index1 = index1.next
                m -= 1
            index2 = index1.next
            index3 = index2.next
            while num_rotate:
                index2.next = index3.next
                index3.next = index1.next
                index1.next = index3
                index3 = index2.next
                num_rotate -= 1
            return myNode.next
  • 相关阅读:
    UNIX网络编程——处理服务器中大量的TIME_WAIT
    UNIX网络编程——套接字选项(心跳检测、绑定地址复用)
    UNIX网络编程——TCP 滑动窗口协议
    [Training Video
    [Training Video
    [Training Video
    [Training Video
    [Training Video
    Use formatter to format your JAVA code
    右键菜单没有新建文本文件了,怎么办?
  • 原文地址:https://www.cnblogs.com/zhuozige/p/12819970.html
Copyright © 2011-2022 走看看