首页 > 其他 > 详细

Rotate Array

时间:2015-03-03 21:51:32      阅读:286      评论:0      收藏:0      [点我收藏+]

方法一:直接开个100010的数组水过。

方法二:编程之美上O(1)的额外空间开销

void reserve(int nums[],int n,int k)
{
    int temp;
    for(int i = k ; i < (n+k)/2 ; i++) {
        temp = nums[i];
        nums[i] = nums[n-i-1+k];
        nums[n-i-1+k] = temp;
    }
}
void rotate(int nums[], int n, int k) {
    k = k%n;
    reserve(nums,n-k,0);
    reserve(nums,n,n-k);
    reserve(nums,n,0);
}

 

Rotate Array

原文:http://www.cnblogs.com/llei1573/p/4311904.html

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