【C++算法】21.二分查找算法_山脉数组的峰顶索引

文章目录


题目链接:

852. 山脉数组的峰顶索引


题目描述:


解法

暴力解法:

若:arr=[0,1,2,3,2,1,0]

可以定义一个指针指向第一个元素,如果它后面的元素比它大,那么他就不是峰值。

当第一次遇到一个数是大于后面那个数的时候,那个数就是峰值。

二分算法:

这边天然的出现了二段性。

这边有一个细节,就是题目给的都是山峰数组,也就意味着数组的开头和结尾两个元素不会是山峰,所以left下标从1开始,right下标从size-2开始。


C++ 算法代码:

暴力解法:

cpp 复制代码
public:
int peakIndexInMountainArray(vector<int>& arr) {
    int n = arr.size();
    // 遍历数组内每一个元素,直到找到峰顶
    for (int i = 1; i < n - 1; i++) 
        // 峰顶满足的条件
        if (arr[i] > arr[i - 1] && arr[i] > arr[i + 1])
            return i; 
    // 为了处理 oj 需要控制所有路径都有返回值
    return -1;
}
};

二分查找:

cpp 复制代码
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;
    }
};

图解

例如:arr=[0,1,2,3,2,1,0]

  1. left = 1, right=5

    进入循环,mid=3

    满足arr[mid] > arr[mid - 1],left = mid=3

  2. left = 3, right=5

    进入循环,mid=4

    right = mid - 1=3

  3. left = 3, right=3

    结束循环,返回3

相关推荐
叫我:松哥几秒前
基于数据挖掘的旅游景点个性化推荐系统设计与实现,Apriori和FP-Growth算法挖掘景点之间的关联规则
人工智能·python·算法·数据挖掘·数据分析·beautifulsoup
SilentSamsara2 分钟前
scikit-learn 工作流工程化:Pipeline、ColumnTransformer 与自定义转换器
开发语言·人工智能·python·机器学习·青少年编程·numpy·scikit-learn
我命由我123453 分钟前
Kotlin 开发 - Kotlin 反引号转义关键字
android·java·开发语言·java-ee·kotlin·android jetpack·android runtime
KaMeidebaby3 分钟前
卡梅德生物技术快报|噬菌体筛选:技术实操:宽谱大肠杆菌噬菌体筛选全流程与性能验证方案
前端·人工智能·算法·数据挖掘·数据分析
大白话_NOI5 分钟前
【洛谷 P1480】A/B Problem(高精度除法 Ⅰ)详细题解
c++
j7~5 分钟前
【C++】C&C++内存管理--之内存分布,operatenew/new,operate/delete的底层原理.
c语言·c++·delete·内存泄漏·new·operate new·动态内存分布
Hillain7 分钟前
软件设计师设计模式
java·开发语言·经验分享·笔记·算法·设计模式·软考
战族狼魂8 分钟前
AI 量化交易完整学习路线(从零到实战)
人工智能·算法·chatgpt·大语言模型·ai提示词·ai工程化
拂拉氏9 分钟前
【项目分享-知识讲解】 C++标准库 list类的模拟实现
开发语言·c++·list·封装·stl标准库
码云骑士10 分钟前
【2.Java基础】Java常量与变量-从基本类型到类型转换全面掌握
java·开发语言