10.轮转数组


大家好,我是晓星航。今天为大家带来的是 轮转数组 相关的讲解!😀

题目简介

题目解答

解法一:使用额外的数组

思路:我们可以使用额外的数组来将每个元素放至正确的位置。用 n 表示数组的长度,我们遍历原数组,将原数组下标为 i 的元素放至新数组下标为 (i+k) mod n 的位置,最后将新数组拷贝至原数组即可。

代码:

class Solution {
    public void rotate(int[] nums, int k) {
        int n = nums.length;
        int[] newArr = new int[n];
        for (int i = 0; i < n; ++i) {
            newArr[(i + k) % n] = nums[i];
        }
        System.arraycopy(newArr, 0, nums, 0, n);
    }
}

这里直接从反转位置开始填入数组元素,可以形象理解为我们把起点改变为了i+k,然后我们在把数组后面填满后再从下标为0的位置开始继续填充元素。(i+k)%n的意义即使在nums数组后面填满后,然后从第一个位置继续填充。
在这里插入图片描述
这里方法的含义是:我们从数组newArr的0下标开始,复制到nums数组从0下标开始,复制n个元素。
在这里插入图片描述

复杂度分析:

时间复杂度: O(n),其中 n 为数组的长度。

空间复杂度: O(n)。


解法二:数组反转

思路:我们直接拿官方的图解就可以很轻易地看出思路
在这里插入图片描述

代码:

class Solution {
    public void reverse(int[] nums,int start,int end) {
        while (start < end) {
            int temp = nums[start];
            nums[start] = nums[end];
            nums[end] = temp;
            start = start + 1;
            end = end - 1;
        }
    }
    public void rotate(int[] nums, int k) {
        k = k % nums.length;
        reverse(nums,0,nums.length - 1);
        reverse(nums,0,k-1);
        reverse(nums,k,nums.length-1);
    }
}

一个很简单的反转数组全部元素的代码:
在这里插入图片描述
这里k模数组长度的作用就是为了避免要轮转的元素个数比数组本身还大,既然轮转一周等于没有轮转,因此我们采取这个方法避免数组越界的问题。
在这里插入图片描述
这三次轮转的作用也很好解释,第一次先把数组整个反转。第二次将前半段反转,第三次将后半段反转,这样就符合题意了,数组是由两个递增数组组合而成。
在这里插入图片描述

复杂度分析:

时间复杂度:O(n),其中 n 为数组的长度。每个元素被翻转两次,一共 n 个元素,因此总时间复杂度为 O(2n)=O(n)。

空间复杂度:O(1)。

题目链接

感谢各位读者的阅读,本文章有任何错误都可以在评论区发表你们的意见,我会对文章进行改正的。如果本文章对你有帮助请动一动你们敏捷的小手点一点赞,你的每一次鼓励都是作者创作的动力哦!😘

相关推荐

  1. 力扣面试150题 | 轮转数组

    2024-05-11 11:48:02       63 阅读
  2. 【力扣100】189.轮转数组

    2024-05-11 11:48:02       59 阅读
  3. 轮转数组 - LeetCode 热题 15

    2024-05-11 11:48:02       40 阅读
  4. 力扣热题100_普通数组_189_轮转数组

    2024-05-11 11:48:02       42 阅读
  5. LeetCode经典150题Golang版.189. 轮转数组

    2024-05-11 11:48:02       68 阅读
  6. 1.5 面试经典150题 - 轮转数组

    2024-05-11 11:48:02       49 阅读
  7. Leetcode面试经典150_Q189轮转数组

    2024-05-11 11:48:02       35 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-11 11:48:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-11 11:48:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-05-11 11:48:02       82 阅读
  4. Python语言-面向对象

    2024-05-11 11:48:02       91 阅读

热门阅读

  1. 代码随想录学习Day 35

    2024-05-11 11:48:02       33 阅读
  2. C语言:初学者和专家的分水岭

    2024-05-11 11:48:02       27 阅读
  3. 设计模式——访问者模式(Visitor)

    2024-05-11 11:48:02       31 阅读
  4. Tensorflow-相关函数

    2024-05-11 11:48:02       27 阅读
  5. Spring Boot 读取配置优先级顺序是什么?

    2024-05-11 11:48:02       33 阅读
  6. 前端表单中的手机号的验证

    2024-05-11 11:48:02       28 阅读