zoukankan      html  css  js  c++  java
  • LeetCode 189. 旋转数组

    189. 旋转数组

    Difficulty: 中等

    给定一个数组,将数组中的元素向右移动 k个位置,其中 k是非负数。

    进阶:

    • 尽可能想出更多的解决方案,至少有三种不同的方法可以解决这个问题。
    • 你可以使用空间复杂度为 O(1) 的 **原地 **算法解决这个问题吗?

    示例 1:

    输入: nums = [1,2,3,4,5,6,7], k = 3
    输出: [5,6,7,1,2,3,4]
    解释:
    向右旋转 1 步: [7,1,2,3,4,5,6]
    向右旋转 2 步: [6,7,1,2,3,4,5]
    向右旋转 3 步: [5,6,7,1,2,3,4]
    

    示例 2:

    输入:nums = [-1,-100,3,99], k = 2
    输出:[3,99,-1,-100]
    解释: 
    向右旋转 1 步: [99,-1,-100,3]
    向右旋转 2 步: [3,99,-1,-100]
    

    提示:

    • 1 <= nums.length <= 2 * 10<sup>4</sup>
    • -2<sup>31</sup> <= nums[i] <= 2<sup>31</sup> - 1
    • 0 <= k <= 10<sup>5</sup>

    Solution

    旋转链表之后旋转数组,以下是思路:先对整个数组旋转,然后分别旋转数组的前k个元素和剩余的数组。

    nums = "----->-->"; k =3
    result = "-->----->";
    
    reverse "----->-->" we can get "<--<-----"
    reverse "<--" we can get "--><-----"
    reverse "<-----" we can get "-->----->"
    

    解法来源:Easy to read Java solution - LeetCode Discuss

    class Solution:
        def rotate(self, nums: List[int], k: int) -> None:
            """
            Do not return anything, modify nums in-place instead.
            """
            k %= len(nums)
            self.reverse(nums, 0, len(nums)-1)
            self.reverse(nums, 0, k-1)
            self.reverse(nums, k, len(nums)-1)
            
        def reverse(self, arr, start, end):
            while start < end:
                arr[start], arr[end] = arr[end], arr[start]
                start += 1
                end -= 1
    

    相似题目:

    LeetCode 61. 旋转链表 - swordspoet - 博客园
    LeetCode 186. 翻转字符串里的单词 II - swordspoet - 博客园

  • 相关阅读:
    js基础面试篇
    vue自定义指令
    vue兄弟节点通信
    vue----打包上线引用外部cdn
    vue----mockjs
    laravel database opearate1
    laravel seeding
    backtotop组件
    配置节流函数
    failed at the chromedriver@2.33.2 install script
  • 原文地址:https://www.cnblogs.com/swordspoet/p/14585594.html
Copyright © 2011-2022 走看看