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

旋转数组的最小数字

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

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

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

全部评论

相关推荐

风中翠竹:真的真的真的没有kpi。。。面试官是没有任何kpi的,捞是真的想试试看这个行不行,碰碰运气,或者是面试官比较闲现在,没事捞个人看看。kpi算HR那边,但是只有你入职了,kpi才作数,面试是没有的。
双非有机会进大厂吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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