题解 | #寻找牛群中的最高牛#

寻找牛群中的最高牛

https://www.nowcoder.com/practice/df826dd3f9304c61bb6e13fcf16652c3

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

        int left = 0, right = heights.size()-1;
        while(left < right)
        {
            int mid = (left+right) >> 1;
            // 为什么跟heights[mid+1]比较,而不跟heights[mid-1]比较呢?因为mid-1可能小于0 ,如heights = {0,1},此时mid = 0, mid-1 = -1;
            
            // mid有可能是峰值所在下标
            if(heights[mid] > heights[mid+1])
                right = mid; 
            // 否则mid+1可能是峰值所在下标
            else
                left = mid+1;
        }

        return left;
    }
};

虚数五行区解题中心 文章被收录于专栏

非淡泊无以明志,非宁静无以致远

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-11 11:29
点赞 评论 收藏
分享
合不合适,我自己说了才算
码农索隆:hr:“真执着啊,来我公司当法人吧”
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 18:05
哈哈哈哈哈感觉朋友找工作的已经疯掉了,直接上图
码农索隆:真老板娘:“我嘞个去,这不我当年的套路吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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