10.轮转数组

文章目录

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

题目简介

题目解答

解法一:使用额外的数组

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

代码:

java 复制代码
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)。


解法二:数组反转

思路:我们直接拿官方的图解就可以很轻易地看出思路

代码:

java 复制代码
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 天前
排序算法:详解插入排序
java·开发语言·后端·算法·排序算法
彦楠1 天前
IDEA实用快捷键
java·ide·intellij-idea
豆沙沙包?1 天前
2025年--Lc197-077. 排序链表(链表,尾插法)--Java版
java·数据结构·链表
m0_651593911 天前
深入理解软件设计中的协议与规范:从理论到Java实践
java·软件工程·代码规范·设计规范
Knight_AL1 天前
Tomcat 类加载器隔离机制的实际应用
java·tomcat
FreeBuf_1 天前
Spring两大漏洞可导致泄露敏感信息及安全防护绕过(CVE-2025-41253/41254)
java·安全·spring
江太翁1 天前
Kotlin 与 Java 互操作中常用注解
java·python·kotlin
知星小度S1 天前
算法训练之多源BFS
算法·宽度优先
notillusion1 天前
URR#69598
java·php·程序优化
2201_758875441 天前
LeetCode:19. 删除链表的倒数第 N 个结点
算法·leetcode·链表