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

旋转数组的最小数字

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

#include <algorithm>
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param nums int整型vector 
     * @return int整型
     */
    int minNumberInRotateArray(vector<int>& nums) {
        // write code here

        sort(nums.begin(), nums.end());

        int l = 0;
        int r = nums.size()-1;
        int mid = 0;
        while (l!=r) {
            mid = (l+r) / 2;
            if (nums[mid] <= nums[mid+1])
            {
                r = mid;
            }
            else if (nums[mid] > nums[mid+1]) {
                l = mid+1;
            }
        }
        return nums[mid];
    }
};

非降序的数组,使用二分法找出最小值。

思路:

使用stl的sort(nums.begin(), nums.end())进行排序;

对排序后的数组,使用二分查找。

因为是非降序的数组,所以当数值相等时,应该往左半侧寻找。

全部评论

相关推荐

07-03 11:02
中山大学 C++
字节刚oc,但距离九月秋招很近了有两段互联网实习,非腾讯字节。不敢赌转正,现在在纠结去还是不去如果实习俩月离职会有什么后果吗
阿城我会做到的:不去后悔一辈子,能否转正取决于ld的态度,只要他不卡,答辩就是走流程,个人觉得可以冲一把
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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