【Leetcode每日一题】二分查找 - 寻找峰值(难度⭐⭐)(20)

1. 题目解析

Leetcode链接:162. 寻找峰值

这个问题的理解其实相当简单,只需看一下示例,基本就能明白其含义了。

核心在于找到题目中所说的峰值并返回他们的下标即可。


2. 算法原理

分析峰顶及其两旁数据的特点

  1. 峰顶数据特点 :峰顶元素arr[i]满足条件arr[i] > arr[i - 1]arr[i] > arr[i + 1],即它大于其前后两个元素。
  2. 峰顶左边数据特点 :对于峰顶左侧的元素arr[i],其满足arr[i] > arr[i - 1]arr[i] < arr[i + 1],这意味着从左侧向峰顶看,数据呈现上升趋势。
  3. 峰顶右边数据特点 :对于峰顶右侧的元素arr[i],其满足arr[i] < arr[i - 1]arr[i] > arr[i + 1],这表明从峰顶向右侧看,数据呈现下降趋势。

根据mid位置信息进行搜索

根据mid位置的数据特点,我们可以分为以下三种情况来缩小搜索范围:

  1. 如果mid位置呈现上升趋势 :这表示当前峰顶还未被找到,且它必定位于mid的右侧。因此,接下来的搜索范围应缩小至[mid + 1, right]区间。
  2. 如果mid位置呈现下降趋势 :这表示当前峰顶位于mid或其左侧。为了找到峰顶,接下来的搜索范围应缩小至[left, mid - 1]区间。
  3. 如果mid位置就是峰顶:在这种情况下,我们已经找到了目标峰顶,可以直接返回结果。

3. 代码编写

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

The Last

嗯,就是这样啦,文章到这里就结束啦,真心感谢你花时间来读。

觉得有点收获的话,不妨给我点个吧!

如果发现文章有啥漏洞或错误的地方,欢迎私信我或者在评论里提醒一声~

相关推荐
iFlyCai12 分钟前
C语言中的指针
c语言·数据结构·算法
查古穆32 分钟前
栈-有效的括号
java·数据结构·算法
再一次等风来33 分钟前
近场声全息(NAH)仿真实现:从阵列实值信号到波数域重建
算法·matlab·信号处理·近场声全息·nah
汀、人工智能34 分钟前
16 - 高级特性
数据结构·算法·数据库架构·图论·16 - 高级特性
你撅嘴真丑37 分钟前
[蓝桥杯 2025 省 B] 生产车间 与 装修报价
职场和发展·蓝桥杯
大熊背38 分钟前
利用ISP离线模式进行分块LSC校正的方法
人工智能·算法·机器学习
XWalnut1 小时前
LeetCode刷题 day4
算法·leetcode·职场和发展
蒸汽求职1 小时前
机器人软件工程(Robotics SDE):特斯拉Optimus落地引发的嵌入式C++与感知算法人才抢夺战
大数据·c++·算法·职场和发展·机器人·求职招聘·ai-native
AI成长日志2 小时前
【笔面试算法学习专栏】双指针专题·简单难度两题精讲:167.两数之和II、283.移动零
学习·算法·面试
旖-旎2 小时前
分治(库存管理|||)(4)
c++·算法·leetcode·排序算法·快速选择算法