39-恢复旋转排序数组
给定一个旋转排序数组,在原地恢复其排序。
说明
什么是旋转数组?
比如,原始数组为[1,2,3,4], 则其旋转数组可以是[1,2,3,4], [2,3,4,1], [3,4,1,2], [4,1,2,3]样例
[4, 5, 1, 2, 3] -> [1, 2, 3, 4, 5]
挑战
使用O(1)的额外空间和O(n)时间复杂度
标签
数组 排序数组
思路——3步排序法
如[4, 5, 1, 2, 3] ,先找到旋转下标index, index=2
- 旋转前部,[4, 5, 1, 2, 3] =》 [5, 4, 1, 2, 3]
- 旋转后部,[4, 5, 1, 2, 3] =》 [5, 4, 3, 2, 1]
- 旋转全部,[4, 5, 1, 2, 3] =》 [1, 2, 3, 4, 5]
code
class Solution {
public:
void recoverRotatedSortedArray(vector<int> &nums) {
// write your code here
int i = 0, size = nums.size();
int index = 0;
for(i=0; i<size-1; i++) {
if(nums[i] > nums[i+1]) {
index = i+1;
break;
}
}
for(i=0; i<index/2; i++) {
int temp = nums[i];
nums[i] = nums[index-1-i];
nums[index-1-i] = temp;
}
for(i=0; i<(size-index)/2; i++) {
int temp = nums[index+i];
nums[index+i] = nums[size-1-i];
nums[size-1-i] = temp;
}
for(i=0; i<size/2; i++) {
int temp = nums[i];
nums[i] = nums[size-1-i];
nums[size-1-i] = temp;
}
}
};