首页 > 编程语言 > 详细

rotate array 旋转数组

时间:2015-07-16 11:03:27      阅读:143      评论:0      收藏:0      [点我收藏+]

class Solution {
public:
void rotate(vector<int>& nums, int k) {

int n=nums.size();
int i=0;

/*

//-------------------

//解法一  会超时

//--------------------
k=k%n;
while(i<k){
  int temp=nums[n-1];
  for(int j=n-1;j>0;j--){
    nums[j]=nums[j-1];
  }
  nums[0]=temp;
  i++;
  }
*/

//-------------------

//解法二

//--------------------

 

vector<int> num1;  新开一个数组,存放
k=k%n;
if(k==0) return;
while(i<k)
{
  num1.push_back(nums[n-k+i]);
  i++;
}
i=0;
while(i<n-k)
{
  num1.push_back(nums[i]);
  i++;
}
i=0;
while(i<n)
{
  nums[i]=num1[i];
  i++;
}

}

//-------------------

//解法三   三次旋转;很巧妙

//--------------------

 

 

 

 

 


};

rotate array 旋转数组

原文:http://www.cnblogs.com/julie-yang/p/4650542.html

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