Leetcode 189 轮转数组

leetcode 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]

https://leetcode.cn/problems/rotate-array/description/

解法一

思路:创建新数组,依次拷贝原数组的元素到新数组,注意下标的转换

时间复杂度:遍历两次,O(n)

空间复杂度:使用了新数组res,O(n)

java 复制代码
class Solution {
    public void rotate(int[] nums, int k) {
        // 方法1:新数组,保存到新数组的正确位置
        // i -> (i+k)%n
        int n = nums.length;
        int[] res = new int[n];
        for (int i = 0; i < n; i++) {
            res[(i+k)%n] = nums[i];
        }
        for (int j = 0; j < n; j++) {
            nums[j] = res[j];
        }
    }  
}

解法二

思路:三次翻转

时间复杂度:三次翻转一共2N次,时间复杂度O(n)

空间复杂度:没有使用额外数组,O(1)

java 复制代码
class Solution {
    public void rotate(int[] nums, int k) {
        // 方法二:假设数组长度为n,按照下面步骤紧张翻转:
        // 全部数组轮转 [0, n-1],[1234567]->[7654321]
        // 前半部分翻转:[0, k-1], [7654321]->[5674321]
        // 后半部分翻转:[k, n-1], [5674321]->[5671234]
        int n = nums.length;
        k = k % n;
        reverse(nums, 0, n-1);
        reverse(nums, 0, k-1);
        reverse(nums, k, n-1);
    }

    void reverse(int[] nums, int start, int end) {
        while (start < end) {
            int temp = nums[start];
            nums[start] = nums[end];
            nums[end] = temp;
            start++;
            end--;
        }
    }
        
}
相关推荐
阿蒙Amon5 分钟前
C#每日面试题-常量和只读变量的区别
java·面试·c#
执携17 分钟前
算法 -- 冒泡排序
数据结构·算法
寻星探路34 分钟前
【算法专题】滑动窗口:从“无重复字符”到“字母异位词”的深度剖析
java·开发语言·c++·人工智能·python·算法·ai
程序员小白条34 分钟前
面试 Java 基础八股文十问十答第八期
java·开发语言·数据库·spring·面试·职场和发展·毕设
萤丰信息41 分钟前
从 “钢筋水泥” 到 “数字神经元”:北京 AI 原点社区重构城市进化新逻辑
java·大数据·人工智能·安全·重构·智慧城市·智慧园区
wen__xvn1 小时前
代码随想录算法训练营DAY14第六章 二叉树 part02
数据结构·算法·leetcode
Ka1Yan1 小时前
[数组] - 代码随想录(2-6)
数据结构·算法·leetcode
week_泽2 小时前
第5课:短期记忆与长期记忆原理 - 学习笔记_5
java·笔记·学习·ai agent
像风一样自由2 小时前
android native 中的函数动态注册方式总结
android·java·服务器·安卓逆向分析·native函数动态注册·.so文件分析
兮动人2 小时前
Maven指定加载的类
java·maven·maven指定加载的类