第一种:
class Solution {
public void rotate(int[] nums, int k) {
int [] afternum=new int[nums.length];
int len=nums.length;
if(k>=nums.length)
k=k-nums.length;
// if(k>nums.length)
int j=0;
for(int i=len-k;i<nums.length;i++)
{
afternum[j++]=nums[i];
}
for(int i=0;i<len-k;i++)
{
afternum[j++]=nums[i];
}
for(int i=0;i<nums.length;i++)
{
nums[i]=afternum[i];
}
}
}
class Solution {
public void rotate(int[] nums, int k) {
k=k%nums.length;
reverse(nums,0,nums.length-1);
reverse(nums,0,k-1);
reverse(nums,k,nums.length-1);
}
public void reverse(int [] nums,int start,int end)
{
int temp;
while(start<end)
{
temp=nums[start];
nums[start]=nums[end];
nums[end]=temp;
start++;
end--;
}
}
}