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

一.网直页达

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;
    }
};
相关推荐
炽烈小老头3 小时前
【每天学习一点算法 2025/12/15】环形链表
学习·算法·链表
点云SLAM3 小时前
算法复杂度分析之——空间复杂度分析和标准库算法与容器操作的复杂度实际案例分析(3)
算法·深度优先·空间复杂度·算法性能分析·标准库算法
Liangwei Lin3 小时前
洛谷 P5788 【模板】单调栈
算法
京东零售技术3 小时前
ACL 2025 | 一种用于电子商务query意图分类的半监督可扩展统一框架
算法
ytttr8734 小时前
matlab实现多标签K近邻(ML-KNN)算法
算法·机器学习·matlab
一招定胜负4 小时前
逻辑回归调优三板斧:参数调整、阈值设定、数据集平衡
算法·机器学习·逻辑回归
豆约翰4 小时前
Z字形扫描ccf
java·开发语言·算法
Salt_07284 小时前
DAY 35 文件的规范拆分和写法
python·算法·机器学习
风筝在晴天搁浅4 小时前
代码随想录 109.冗余连接Ⅱ
算法