【LeetCode每日一题】——189.轮转数组

文章目录

一【题目类别】

  • 数组

二【题目难度】

  • 中等

三【题目编号】

  • 189.轮转数组

四【题目描述】

  • 给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。

五【题目示例】

  • 示例 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 < = n u m s . l e n g t h < = 1 0 5 1 <= nums.length <= 10^5 1<=nums.length<=105
  • − 2 31 < = n u m s [ i ] < = 2 31 − 1 -2^{31} <= nums[i] <= 2^{31} - 1 −231<=nums[i]<=231−1
  • 0 < = k < = 1 0 5 0 <= k <= 10^5 0<=k<=105

七【题目进阶】

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

八【解题思路】

  • 假设需要轮转k个位置,那么我们需要进行三次翻转:
    • 第一次翻转:翻转整个数组,此时需要移动的元素已经到了数组的开始,其余元素在数组的后面
    • 第二次翻转:将第一次翻转到数组开始的k个元素翻转,这样就变成了正常的顺序
    • 第三次翻转,将第一次翻转到数组后面的剩余元素翻转,这样也变成了正常的顺序
  • 当然,我们还要合理的处理k以避免溢出
  • 该题不需要返回结果
  • 具体细节可以参考下面的代码

九【时空频度】

  • 时间复杂度: O ( n ) O(n) O(n), n n n为传入的数组的长度
  • 空间复杂度: O ( 1 ) O(1) O(1)

十【代码实现】

  1. Java语言版
java 复制代码
class Solution {
    public void rotate(int[] nums, int k) {
        // 防止溢出
        int n = nums.length;
        k %= n;
        // 第一次翻转:翻转整个数组,此时需要移动的元素已经到了数组的开始,其余元素在数组的后面
        reverse(nums, 0, n - 1);
        // 第二次翻转:将第一次翻转到数组开始的k个元素翻转,这样就变成了正常的顺序
        reverse(nums, 0, k - 1);
        // 第三次翻转,将第一次翻转到数组后面的剩余元素翻转,这样也变成了正常的顺序
        reverse(nums, k, n - 1);
    }

    // 翻转数组
    private void reverse(int[] nums, int start, int end) {
        while (start < end) {
            int temp = nums[start];
            nums[start] = nums[end];
            nums[end] = temp;
            start++;
            end--;
        }
    }

}
  1. Python语言版
python 复制代码
class Solution:
    def rotate(self, nums: List[int], k: int) -> None:
        # 防止溢出
        k %= len(nums)
        # 第一次翻转:翻转整个数组,此时需要移动的元素已经到了数组的开始,其余元素在数组的后面
        self.reverse(nums, 0, len(nums) - 1)
        # 第二次翻转:将第一次翻转到数组开始的k个元素翻转,这样就变成了正常的顺序
        self.reverse(nums, 0, k - 1)
        # 第三次翻转,将第一次翻转到数组后面的剩余元素翻转,这样也变成了正常的顺序
        self.reverse(nums, k, len(nums) - 1)

    # 翻转数组
    def reverse(self, nums, start, end):
        while start < end:
            temp = nums[end]
            nums[end] = nums[start]
            nums[start] = temp
            start += 1
            end -= 1
  1. C语言版
c 复制代码
// 翻转数组
void reverse(int* nums, int start, int end)
{
    while (start < end)
    {
        int temp = nums[start];
        nums[start] = nums[end];
        nums[end] = temp;
        start++;
        end--;
    }
}

void rotate(int* nums, int numsSize, int k)
{
    // 防止溢出
    k %= numsSize;
    // 第一次翻转:翻转整个数组,此时需要移动的元素已经到了数组的开始,其余元素在数组的后面
    reverse(nums, 0, numsSize - 1);
    // 第二次翻转:将第一次翻转到数组开始的k个元素翻转,这样就变成了正常的顺序
    reverse(nums, 0, k - 1);
    // 第三次翻转,将第一次翻转到数组后面的剩余元素翻转,这样也变成了正常的顺序
    reverse(nums, k, numsSize - 1);
}

十一【提交结果】

  1. Java语言版

  2. Python语言版

  3. C语言版

相关推荐
大千AI助手1 小时前
DTW模版匹配:弹性对齐的时间序列相似度度量算法
人工智能·算法·机器学习·数据挖掘·模版匹配·dtw模版匹配
好好研究2 小时前
学习栈和队列的插入和删除操作
数据结构·学习
YuTaoShao3 小时前
【LeetCode 热题 100】48. 旋转图像——转置+水平翻转
java·算法·leetcode·职场和发展
生态遥感监测笔记3 小时前
GEE利用已有土地利用数据选取样本点并进行分类
人工智能·算法·机器学习·分类·数据挖掘
Tony沈哲3 小时前
macOS 上为 Compose Desktop 构建跨架构图像处理 dylib:OpenCV + libraw + libheif 实践指南
opencv·算法
刘海东刘海东4 小时前
结构型智能科技的关键可行性——信息型智能向结构型智能的转变(修改提纲)
人工智能·算法·机器学习
pumpkin845144 小时前
Rust 调用 C 函数的 FFI
c语言·算法·rust
挺菜的5 小时前
【算法刷题记录(简单题)003】统计大写字母个数(java代码实现)
java·数据结构·算法
mit6.8245 小时前
7.6 优先队列| dijkstra | hash | rust
算法