//把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。
//初次 测试通过 但是有问题 333123
class Solution {
public:
int minNumberInRotateArray(vector<int> rotateArray)
{
if (rotateArray.empty())
return 0;
int right = rotateArray.size() - 1;
int left = 0;
while(left<right)
{
if (rotateArray[left] < rotateArray[right])//这里不能有= for 345123
return rotateArray[left];
int middle = (left + right)/2;
if (rotateArray[middle] <= rotateArray[right])//这里<和=不能合并 333123
{
right = middle;
}
else if(rotateArray[middle] > rotateArray[right])
{
left = middle + 1;
}
}
return rotateArray[left];
}
};
//修改
class Solution {
public:
int minNumberInRotateArray(vector<int> rotateArray)
{
if (rotateArray.empty())
return 0;
int right = rotateArray.size() - 1;
int left = 0;
while(left<right)
{
if (rotateArray[left] < rotateArray[right])//这里不能有= for 345123
return rotateArray[left];
int middle = (left + right)/2;
if (rotateArray[middle] < rotateArray[right])//这里<和=不能合并 333123
{
right = middle;
}
else if(rotateArray[middle] > rotateArray[right])
{
left = middle + 1;
}
else
{
right -= 1;
}
}
return rotateArray[left];
}
};