LeetCode热题100——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 <= nums.length <= 10^5
  • -2^31 <= nums[i] <= 2^31 - 1
  • 0 <= k <= 10^5

题解:

观察旋转后的数组特点:

  • 原数组 [1,2,3,4,5,6,7] 向右旋转 3 步后得到 [5,6,7,1,2,3,4]

  • 旋转结果可以看作:原数组的后 k 个元素移到前面,前 n-k 个元素移到后面

利用数组**反转(reverse)**可以在 O(1) 额外空间内实现:

  1. 反转整个数组 → 后 k 个元素跑到了前 k 个位置,但顺序是反的。

  2. 反转前 k 个元素 → 将前 k 个元素恢复正确顺序。

  3. 反转后 n-k 个元素 → 将剩余元素恢复正确顺序。

答案:

cpp 复制代码
class Solution {
public:
    void rotate(vector<int>& nums, int k) {
        if(nums.size()==0) return;
        k=k%nums.size();
        if(k==0) return;
        //reverse(first, last) 反转的是 [first, last) 区间,左闭右开,即包含 first 指向的元素,不包含 last 指向的元素。
        //反转整个数组
        reverse(nums.begin(),nums.end());
        //反转前 k 个元素
        reverse(nums.begin(),nums.begin()+k);
        //反转后 n-k 个元素
        reverse(nums.begin()+k,nums.end());       
    }
};

要点:

  • 反转区间 :C++ 标准库 reverse(first, last) 反转的是**[first, last)** 左闭右开区间。
  • k 可能大于数组长度 :当 k 大于数组长度时,向右轮转 n 步(n 为数组长度)会使数组完全回到原始状态。所以需执行 **k = k % nums.size()**来得到真正需要移动的步数。
相关推荐
IT大白鼠12 小时前
AIGC性能的关键瓶颈:算力、数据、算法三者如何互相制约?
算法·aigc
tjl521314_2113 小时前
04C++ 名称空间(Namespace)
开发语言·c++
ximu_polaris13 小时前
设计模式(C++)-行为型模式-备忘录模式
c++·设计模式·备忘录模式
白雪茫茫13 小时前
监督学习、半监督学习、无监督学习算法详解
python·学习·算法·ai
FengyunSky13 小时前
浅析 空间频率响应 SFR 计算
算法
树下水月13 小时前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集14 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考15 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
流年如夢15 小时前
单链表进阶版 -->双向链表
数据结构·链表
刀法如飞16 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法