山脉数组的峰顶索引_优选算法_二分查找法

一.网直页达

https://leetcode.cn/problems/B1IidL/

二.题目解析

分析:我们发现数组就像一个山峰一样的,会有一个最高点

解法一:暴力解法

我们现在来进行优化,,我们发现,峰值两边都会有单增加和单减的特性,我们发现数组分成了两部,即具有二段性,我们就可以使用二分查找法

解法二:二分查找法

mid=left+(right-left)/2

三.代码实现

1.无注释:

复制代码
class Solution {
public:
    int peakIndexInMountainArray(vector<int>& arr) {
            int left=1,right=arr.size()-2;
            while(left<right)
            {
                int mid=left+(right-left+1)/2;
                if(arr[mid]>arr[mid-1]) left=mid;
                else right=mid-1;
            }
        return left;
    }
};

2.注释详解

复制代码
class Solution {
public:
    int peakIndexInMountainArray(vector<int>& arr) {
            int left=1,right=arr.size()-2;//俩边的数是直接成立的
            while(left<right)
            {
                int mid=left+(right-left+1)/2;//中间值需要考虑数据溢出的问题
                if(arr[mid]>arr[mid-1]) left=mid;
                else right=mid-1;//我们要找的是峰值,所以需要向左移动
            }
        return left;
    }
};
相关推荐
哎嗨人生公众号26 分钟前
手写求导公式,让轨迹优化性能飞升,150ms变成9ms
开发语言·c++·算法·机器人·自动驾驶
foundbug99930 分钟前
STM32 内部温度传感器测量程序(标准库函数版)
stm32·单片机·嵌入式硬件·算法
Hello.Reader30 分钟前
为什么学线性代数(一)
线性代数·算法·机器学习
_深海凉_37 分钟前
LeetCode热题100-找到字符串中所有字母异位词
算法·leetcode·职场和发展
木井巳41 分钟前
【递归算法】目标和
java·算法·leetcode·决策树·深度优先
旖-旎1 小时前
哈希表(字母异位次分组)(5)
数据结构·c++·算法·leetcode·哈希算法·散列表
别或许1 小时前
4、高数----一元函数微分学的计算
人工智能·算法·机器学习
_深海凉_1 小时前
LeetCode热题100-最长连续序列
算法·leetcode·职场和发展
这里没有酒1 小时前
[信息安全] AES128 加密/解密 --> state 矩阵
算法
无限进步_1 小时前
【C++】多重继承中的虚表布局分析:D类对象为何有两个虚表?
开发语言·c++·ide·windows·git·算法·visual studio