题解 | #旋转数组的最小数字#

旋转数组的最小数字

https://www.nowcoder.com/practice/9f3231a991af4f55b95579b44b7a01ba

/**
 *
 * @param rotateArray int整型一维数组
 * @param rotateArrayLen int rotateArray数组长度
 * @return int整型
 */
int minNumberInRotateArray(int* rotateArray, int rotateArrayLen) 
{
    int left = 0;
    int right = 0;
    int mid = 0;
    int max = 0;
    int i = 0;
    for (left = 0, right = rotateArrayLen - 1; left < right;) {
        mid = left + (right - left) / 2;
        if (rotateArray[mid + 1] < rotateArray[mid])
            return rotateArray[mid+1];
        if (rotateArray[right] > rotateArray[mid])
            right = mid;
        else if(rotateArray[right] < rotateArray[mid])
            left = mid;
        else 
            right--;
    }
     return rotateArray[left];
    // write code here
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-08 13:05
点赞 评论 收藏
分享
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-08 12:05
俺不中了,BOSS遇到了一个hr,我觉得我咨询的问题都很正常吧,然后直接就被拒绝了???
恶龙战士:你问的太多了,要不就整理成一段话直接问他,一个一个问不太好
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务