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

旋转数组的最小数字

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())进行排序;

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

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

全部评论

相关推荐

09-13 10:40
门头沟学院 Java
听别人介绍,刷了一堆力扣题,考场上写函数,一直无法通过。赛后才知道要自己写输入输出,力扣害人不浅
Silencer76:输入输出练习题单,请https://www.nowcoder.com/exam/oj?page=1&tab=%E7%AE%97%E6%B3%95%E7%AC%94%E9%9D%A2%E8%AF%95%E7%AF%87&topicId=372
点赞 评论 收藏
分享
亲切的00后在笔试:我也遇到了,所以我早他一步查看图片
点赞 评论 收藏
分享
头像
09-01 09:00
已编辑
四川旅游学院 运营
牛客55195891...:主要是专业不好,别的没毛病
牛客解忧铺
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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