首页 > 编程语言 > 详细

[LeetCode] Rotate Array 旋转数组

时间:2015-02-24 16:17:59      阅读:1453      评论:0      收藏:0      [点我收藏+]

 

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?

Credits:
Special thanks to @Freezen for adding this problem and creating all test cases.

 

新题抢先刷,这道题标为Easy,应该不是很难,题目明确要求了空间复杂度为O(1),那么肯定不能建立新的数组,所以只能覆盖原数组的值,仔细观察题目中给的那个例子,k = 3说是移动了三步,怎么移的呢,原来是每次把最末尾的数移动到开头,移三次就得到最终结果。代码如下:

 

class Solution {
public:
    void rotate(int nums[], int n, int k) {
        for (int i = 0; i < k; ++i) {
            moveRight(nums, n);
        }        
    }
    void moveRight(int nums[], int n) {
        if (n == 0) return;
        int last = nums[n - 1];
        for (int i = n - 1; i >= 1; --i) nums[i] = nums[i - 1];
        nums[0] = last;
    }
};

 

题目说至少有三种解法,暂时只想到一种,容我慢慢想想~~

 

[LeetCode] Rotate Array 旋转数组

原文:http://www.cnblogs.com/grandyang/p/4298711.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!