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

旋转数组的最小数字

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

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

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

全部评论

相关推荐

不愿透露姓名的神秘牛友
11-27 10:52
点赞 评论 收藏
分享
11-11 14:21
西京学院 C++
无敌混子大王:首先一点,不管学校层次怎么样,教育经历放在第一页靠上位置,第一页看不到教育经历,hr基本直接扔掉了
点赞 评论 收藏
分享
10-11 17:45
门头沟学院 Java
走吗:别怕 我以前也是这么认为 虽然一面就挂 但是颇有收获!
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务