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--;
        }
    }
        
}
相关推荐
会叫的恐龙3 小时前
C++ 核心知识点汇总(第11日)(排序算法)
c++·算法·排序算法
twilight_4693 小时前
机器学习与模式识别——线性回归算法
算法·机器学习·线性回归
知识即是力量ol3 小时前
初识 Kafka(一):分布式流平台的定义、核心优势与架构全景
java·分布式·kafka·消息队列
玄同7653 小时前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm
爱吃生蚝的于勒3 小时前
【Linux】线程概念(一)
java·linux·运维·服务器·开发语言·数据结构·vim
kong79069283 小时前
Nginx性能优化
java·nginx·性能优化
Pluchon3 小时前
硅基计划4.0 算法 简单模拟实现位图&布隆过滤器
java·大数据·开发语言·数据结构·算法·哈希算法
我命由我123453 小时前
Java 泛型 - Java 泛型通配符(上界通配符、下界通配符、无界通配符、PECS 原则)
java·开发语言·后端·java-ee·intellij-idea·idea·intellij idea
Seven973 小时前
AQS深度探索:以ReentrantLock看Java并发编程的高效实现
java
独断万古他化3 小时前
【算法通关】前缀和:和为 K、和被 K整除、连续数组、矩阵区域和全解
算法·前缀和·矩阵·哈希表