news 2026/4/23 18:54:37

寻找峰值--优选算法(二分查找法)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
寻找峰值--优选算法(二分查找法)

一.网页直达

https://leetcode.cn/problems/find-peak-element

二.题目解析

解析:

题目上给出的时间复杂度就暗示我们需要使用二分算法,我们发现相邻位置没有相同的数字.

我们先来想暴力解法:遍历数组,利用单调性的变化来判断是否是峰值,或者是单调不变的那峰值就是第一个数或者是最后一个数.(一共三种情况),时间复杂度就是O(N)

我们抽象出一个模型出来,找到二段性,使用二分查找.

情况一就是arr[mid]>arr[mid+1],说明结果一定在二段性的左边.while更新右边区间right=mid,继续寻找峰值.

情况二:就是arr[mid]<arr[mid+1],说明结果一定在二段性的右边.while更新左边区间left=mid+1,继续寻找峰值.

代码实现:

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

二分法不是只在单调区间里面的,只需要找到二段性,就可以使用.

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 14:40:57

21、帧缓冲接口设计与红外远程控制技术详解

帧缓冲接口设计与红外远程控制技术详解 帧缓冲接口设计 在图形用户界面(GUI)的构建中,帧缓冲接口的设计是至关重要的一环。下面将详细介绍如何设计一个帧缓冲接口,以及如何使用它来构建一个简单的菜单系统。 按键事件处理 在处理按键事件时,我们可以使用SDL(Simple D…

作者头像 李华
网站建设 2026/4/23 14:36:07

工具泛滥是智能体腐败的开始:我们如何执行「工具生命周期」管理

在过去一年里&#xff0c;我参与和评审过不少 AI 智能体项目&#xff0c;从 Demo 到真正上线商业环境。一个非常普遍、但很少被系统性讨论的问题反复出现&#xff1a;智能体失败&#xff0c;往往不是模型不行&#xff0c;而是工具失控。很多团队在构建 Agent 时&#xff0c;把「…

作者头像 李华