39. 恢复旋转排序数组
给定一个旋转排序数组,在原地恢复其排序。
样例
Example1:
[4, 5, 1, 2, 3]
->[1, 2, 3, 4, 5]
Example2:[6,8,9,1,2]
->[1,2,6,8,9]
挑战
使用O(1)的额外空间和O(n)时间复杂度
说明
什么是旋转数组?
- 比如,原始数组为[1,2,3,4], 则其旋转数组可以是[1,2,3,4], [2,3,4,1], [3,4,1,2], [4,1,2,3]
class Solution {
public:
void recoverRotatedSortedArray(vector<int> &nums) {
// write your code here
int size=nums.size(),i;
for(i=1;i<size;i++)
{
if(nums[i]<nums[i-1])
{
break;
}
}
if(i==size)
{
return;
}
rotateArray(nums,0,i-1);
rotateArray(nums,i,size-1);
rotateArray(nums,0,size-1);
}
void rotateArray(vector<int> &nums, int begin, int end)
{
int temp;
while(begin<end)
{
temp=nums[begin];
nums[begin]=nums[end];
nums[end]=temp;
begin++;
end--;
}
}
};