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

一.网直页达

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;
    }
};
相关推荐
仍然.16 小时前
JavaDataStructure---排序
数据结构·算法·排序算法
ZhuNian的学习乐园17 小时前
LLM知识检索增强:RAG_系统化解析与工程实践
人工智能·算法
WBluuue17 小时前
Codeforces Good Bye 2025 Div1+2(ABCDE)
c++·算法
骑自行车的码农17 小时前
🕹️ 设计一个 React 重试
前端·算法·react.js
代码游侠17 小时前
应用——MQTT客户端开发
服务器·c语言·开发语言·数据结构·算法
蓝天下的守望者17 小时前
由continue引发的一个debug灾难
算法·systemverilog
明洞日记17 小时前
【VTK手册034】 vtkGeometryFilter 深度解析:高性能几何提取与转换专家
c++·图像处理·算法·ai·vtk·图形渲染
额呃呃17 小时前
operator new/delete
开发语言·c++·算法
hweiyu0018 小时前
二分图匹配算法:匈牙利算法
算法
IAR Systems18 小时前
在IAR Embedded Workbench for Renesas RH850中实现ROPI
linux·运维·算法