算法入门21——二分查找算法——山脉数组的峰顶索引

1.题目

给定一个长度为 n 的整数 山脉 数组 arr ,其中的值递增到一个 峰值元素 然后递减。

返回峰值元素的下标。

你必须设计并实现时间复杂度为 O(log(n)) 的解决方案。

示例 1:

复制代码
输入:arr = [0,1,0]
输出:1

示例 2:

复制代码
输入:arr = [0,2,1,0]
输出:1

示例 3:

复制代码
输入:arr = [0,10,5,2]
输出:1

提示:

  • 3 <= arr.length <= 105
  • 0 <= arr[i] <= 106
  • 题目数据 保证 arr 是一个山脉数组

2.算法原理

cpp 复制代码
class Solution 
{
public:
    int peakIndexInMountainArray(vector<int>& arr) 
    {
        int left = 1,right = arr.size()-2;
        while(left < right)
        {
            int mid = left + (right-left)/2;
            if(arr[mid]>arr[mid+1] && (mid + 1) != arr.size()) right = mid;
            else left = mid+1;
        }
        return left;
    }
};
相关推荐
only-qi4 分钟前
leetcode24两两交换链表中的节点 快慢指针实现
数据结构·算法·链表
多恩Stone7 分钟前
【3D AICG 系列-9】Trellis2 推理流程图超详细介绍
人工智能·python·算法·3d·aigc·流程图
sin_hielo8 分钟前
leetcode 110
数据结构·算法·leetcode
整得咔咔响9 分钟前
贝尔曼最优公式(BOE)
人工智能·算法·机器学习
日拱一卒——功不唐捐10 分钟前
字符串匹配:暴力法和KMP算法(C语言)
c语言·算法
renke336419 分钟前
Flutter for OpenHarmony:数字涟漪 - 基于扩散算法的逻辑解谜游戏设计与实现
算法·flutter·游戏
AI科技星24 分钟前
从ZUFT光速螺旋运动求导推出自然常数e
服务器·人工智能·线性代数·算法·矩阵
老鼠只爱大米27 分钟前
LeetCode经典算法面试题 #78:子集(回溯法、迭代法、动态规划等多种实现方案详细解析)
算法·leetcode·动态规划·回溯·位运算·子集
执着25931 分钟前
力扣hot100 - 199、二叉树的右视图
数据结构·算法·leetcode
I_LPL35 分钟前
day21 代码随想录算法训练营 二叉树专题8
算法·二叉树·递归