轮转数组

简介: 轮转数组

轮转数组(算法题)

题目:给你一个数组,将数组中的元素向右轮转 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 <= 105
  • -231 <= nums[i] <= 231 - 1
  • 0 <= k <= 105

思路

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

class Solution {
public:
    void rotate(vector<int>& nums, int k) {
        int n = nums.size();
        vector<int> newArr(n);
        for (int i = 0; i < n; ++i) {
            newArr[(i + k) % n] = nums[i];
        }
        nums.assign(newArr.begin(), newArr.end());
    }
};
相关文章
|
5月前
189. 轮转数组 leetcode
189. 轮转数组 leetcode
38 0
|
5月前
189. 轮转数组
189. 轮转数组
31 0
|
5月前
|
算法
【力扣】189.轮转数组
【力扣】189.轮转数组
|
5月前
leetcode-189:轮转数组
leetcode-189:轮转数组
51 1
|
5月前
面试题 01.09:字符串轮转
面试题 01.09:字符串轮转
40 0
|
10月前
|
机器学习/深度学习 算法
【LeetCode刷题日志】189.轮转数组
【LeetCode刷题日志】189.轮转数组
图解LeetCode——189. 轮转数组
图解LeetCode——189. 轮转数组
91 1
|
算法
(leetcode)189. 轮转数组
(leetcode)189. 轮转数组
47 0