反转前半部分,在反转后半部分,最后整个反转。
void rotate(vector<int>& nums, int k) {
int len = nums.size();
k = k % len;
reverse(nums,0,len-k-1);
reverse(nums,len-k,len-1);
reverse(nums,0,len-1);
}
void reverse(vector<int>& nums,int head,int tail){
while(head<tail){
int tmp = nums[head];
nums[head++] = nums[tail];
nums[tail--] = tmp;
}
}
本文介绍了一种有效的数组旋转算法,通过三次反转实现数组元素的旋转。首先反转前半部分,接着反转后半部分,最后再反转整个数组,以此达到数组旋转的效果。文中提供了详细的C++代码实现。
345

被折叠的 条评论
为什么被折叠?



