leetcodeOJ 189. Rotate Array

来源:互联网 发布:淘宝地址怎么删除不了 编辑:程序博客网 时间:2024/05/21 10:16

Rotate an array of n elements to the right by k steps.

For example, with n = 7 and k = 3, the array [1,2,3,4,5,6,7] is rotated to [5,6,7,1,2,3,4].

Note:
Try to come up as many solutions as you can, there are at least 3 different ways to solve this problem.

[show hint]

Hint:

Could you do it in-place with O(1) extra space?


class Solution {public:    void rotate(vector<int>& nums, int k) {        int n = nums.size();        if(n == 0 || k == 0)            return;        k = k%n;                reverse(nums.begin(), nums.begin()+n-k);        reverse(nums.begin()+n-k, nums.end());        reverse(nums.begin(), nums.end());            }};


0 0
原创粉丝点击