轮转数组

简介: 轮转数组

轮转数组(算法题)

题目:给你一个数组,将数组中的元素向右轮转 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());
    }
};
相关文章
|
8月前
189. 轮转数组 leetcode
189. 轮转数组 leetcode
50 0
|
8月前
189. 轮转数组
189. 轮转数组
38 0
|
8月前
|
算法
【力扣】189.轮转数组
【力扣】189.轮转数组
|
算法 C语言
【数据结构】--189.轮转数组
【数据结构】--189.轮转数组
【数据结构】--189.轮转数组
|
8月前
|
弹性计算 运维 Shell
自动日志文件轮转
【4月更文挑战第30天】
50 0
|
8月前
leetcode-189:轮转数组
leetcode-189:轮转数组
63 1
|
8月前
面试题 01.09:字符串轮转
面试题 01.09:字符串轮转
56 0
|
算法
(leetcode)189. 轮转数组
(leetcode)189. 轮转数组
61 0

热门文章

最新文章

下一篇
开通oss服务