给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。
示例 1:
输入: [1,2,3,4,5,6,7] 和 k = 3
输出: [5,6,7,1,2,3,4]
解释:
向右旋转 1 步: [7,1,2,3,4,5,6]
向右旋转 2 步: [6,7,1,2,3,4,5]
向右旋转 3 步: [5,6,7,1,2,3,4]
示例 2:
输入: [-1,-100,3,99] 和 k = 2
输出: [3,99,-1,-100]
解释:
向右旋转 1 步: [99,-1,-100,3]
向右旋转 2 步: [3,99,-1,-100]
C
void reverse1(int* a,int s,int e)
{
while(s<e)
{
int temp=a[e];
a[e]=a[s];
a[s]=temp;
e--;
s++;
}
}
void rotate(int* nums, int numsSize, int k){
if(k>=numsSize)
k%=numsSize;
if(k!=0)
{
reverse1(nums,0,numsSize-k-1);
reverse1(nums,numsSize-k,numsSize-1);
reverse1(nums,0,numsSize-1);
}
}
网友评论