题解 | 寻找峰值

寻找峰值

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

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param nums int整型一维数组 
 * @param numsLen int nums数组长度
 * @return int整型
 */
int findPeakElement(int* nums, int numsLen ) {
    // write code here
    if (numsLen == 0) {
        return 0;
    }

    int left = 0;
    int right = numsLen - 1;
    int mid;

    while (left<right) {
        mid =left+(right-left)/2;
        if (nums[mid] > nums[mid + 1]) {
            // 左侧有峰值,因为右边是下降趋势
            right = mid;
        } else {
            // 右侧有峰值,因为右边是上升趋势
            left = mid + 1;
        }
    }
    return left;
}

全部评论

相关推荐

03-01 21:45
中北大学 Python
孤蓝长空:请你说一下为什么你用websocket而不是http,请你说一下什么是rpc,为什么用rpc,你的rpc的传输协议是JSON,xml还是什么 请你描述一下你的鉴权流程(完整的) 我问的是第二个项目,随便问的哈哈哈
开工第一帖
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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