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

旋转数组的最小数字

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-21 19:05
点赞 评论 收藏
分享
11-08 17:36
诺瓦科技_HR
点赞 评论 收藏
分享
牛客963010790号:为什么还要收藏
点赞 评论 收藏
分享
字节 飞书绩效团队 (n+2) * 15 + 1k * 12 + 1w
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务