【优选算法必刷100题】第021-022题(二分查找):山峰数组的的峰顶索引、寻找峰值

【优选算法必刷100题】第021-022题(二分查找):山峰数组的的峰顶索引、寻找峰值

🔥个人主页:Cx330🌸

❄️个人专栏:《C语言》《LeetCode刷题集》《数据结构-初阶》《C++知识分享》

《优选算法指南-必刷经典100题》《Linux操作系统》:从入门到入魔

🌟心向往之行必能至


🎥Cx330🌸的简介:


目录

前言:

21. 山峰数组的的峰顶索引

解法(二分查找):

算法思路:

二分查找解法代码(C++):

22. 寻找峰值

解法(二分查找):

算法思路:

二分查找解法代码(C++):

总结:


前言:

聚焦算法题实战,系统讲解三大核心板块:“精准定位最优解”——优选算法,“简化逻辑表达,系统性探索与剪枝优化”——递归与回溯,“以局部最优换全局高效”——贪心算法,讲解思路与代码实现,帮助大家快速提升代码能力

二分查找专题


21. 山峰数组的的峰顶索引

题目链接:

852. 山脉数组的峰顶索引 - 力扣(LeetCode)

题目描述:

题目示例:

解法(二分查找):

这里暴力解法大家自己实现一下,我就不实现了

算法思路:

分析峰顶位置的数据特点,以及山峰两旁的数据的特点:

  • 峰顶数据特点:arr[ i ] > arr[ i-1 ] &&[ i ]>arr[ i+1 ]
  • 峰顶左边的数据特点:arr[ i ] > arr[i-1] && arr[ i ] < arr [ i+1 ],呈上升趋势
  • 峰顶右边数据的特点:arr[ i ] < arr[ i-1 ] && arr[ i ] > arr[ i+1 ],呈下降趋势

由此我们可以分为以下两种情况:

  • 如果 mid 位置的值小于 mid-1 位置的值 left=mid
  • 如果 mid 位置的值大于 mid-1 位置的值 right=mid-1

二分查找解法代码(C++):

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; } };

22. 寻找峰值

题目链接:

162. 寻找峰值 - 力扣(LeetCode)

题目描述:

题目示例:

解法(二分查找):

算法思路:

判断二段性:任取一个点 i,与下一个点 i+1,会有如下两种情况:

  • arr[ i ] > arr[ i+1 ]:此时【左侧区域】一定会存在山峰(因为最左侧是负无穷),那么我们就可以去左侧寻找结果
  • arr[ i ] < arr[ i+1]:此时【右侧区域】一定会存在山峰(因为最右侧是负无穷),那么我们就可以去右侧寻找结果
点睛之笔:如果我们找到了二段性,就可以尝试用二分法解题了!

二分查找解法代码(C++):

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; } };

总结:

往期回顾:【优选算法必刷100题】第019-020题:x的平方根和搜索插入位置

Read more

Flutter 组件 meeting_place_core 的适配 鸿蒙Harmony 实战 - 驾驭分布式会议引擎、实现鸿蒙端高性能协作空间与复杂信令分发方案

Flutter 组件 meeting_place_core 的适配 鸿蒙Harmony 实战 - 驾驭分布式会议引擎、实现鸿蒙端高性能协作空间与复杂信令分发方案

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 meeting_place_core 的适配 鸿蒙Harmony 实战 - 驾驭分布式会议引擎、实现鸿蒙端高性能协作空间与复杂信令分发方案 前言 在后疫情时代的协同办公浪潮中,视频会议已经从单一的垂直应用演变为鸿蒙(OpenHarmony)生态中“泛在协作”的核心基础设施。当你在鸿蒙平板上开启一场跨国技术评审,或者在鸿蒙车机上紧急连线公司晨会时,支撑这一切流畅运行的,是底层极其复杂的会议核心引擎。 meeting_place_core 是一套工业级的、专为多端同步设计的会议核心抽象包。它不负责 UI 渲染,而是专注于房间管理(Room Management)、成员状态流转、信令推送及媒体流的逻辑编排。 适配到鸿蒙平台后,结合鸿蒙强大的分布式能力,meeting_place_core 能让你的 App 轻松实现“手机开会,大屏投映,

By Ne0inhk
Spring Cloud动态配置刷新:@RefreshScope与@Component的深度解析

Spring Cloud动态配置刷新:@RefreshScope与@Component的深度解析

个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[[email protected]] 📱个人微信:15279484656 🌐个人导航网站:www.forff.top 💡座右铭:总有人要赢。为什么不能是我呢? * 专栏导航: 码农阿豪系列专栏导航 面试专栏:收集了java相关高频面试题,面试实战总结🍻🎉🖥️ Spring5系列专栏:整理了Spring5重要知识点与实战演练,有案例可直接使用🚀🔧💻 Redis专栏:Redis从零到一学习分享,经验总结,案例实战💐📝💡 全栈系列专栏:海纳百川有容乃大,可能你想要的东西里面都有🤸🌱🚀 目录 * Spring Cloud动态配置刷新:@RefreshScope与@Component的深度解析 * 引言 * 1. `@RefreshScope` 的作用与原理 * 1.1 什么是 `@RefreshScope`? * 1.

By Ne0inhk
Spring Boot 4.0 新特性全解析 + 实操指南

Spring Boot 4.0 新特性全解析 + 实操指南

Spring Boot 4.0 新特性全解析 + 实操指南 作者:技术小栈 | 日期:2026-01-02 引言:Spring Boot 4.0 作为生态内的重大更新,基于 Spring Framework 6.1+ 构建,带来了一系列颠覆性优化——从强制 Java 17+ 适配到原生镜像支持升级,从 HTTP/3 原生集成到 Testcontainers 简化,每一项特性都直指「性能提升」与「开发效率优化」。本文将带你逐个拆解核心新特性,搭配可直接复用的代码示例,手把手教你落地使用,同时附上迁移避坑指南,助你快速升级上手! 一、前置准备:升级 Spring Boot 4.0 必看前提

By Ne0inhk
2026最新版Node.js下载安装及环境配置教程【保姆级教程】

2026最新版Node.js下载安装及环境配置教程【保姆级教程】

一、进入官网地址下载安装包 Node.js 中文网 选择对应你系统的Node.js版本,这里我选择的是Windows系统、64位 这里我会给同学们把链接放到这里大家可以复制链接下载资源 二、安装程序 (1)下载完成后,双击安装包,开始安装Node.js (2)直接点【Next】按钮,此处可根据个人需求修改安装路径,修改完毕后继续点击【Next】按钮 (3)可根据自身需求进行,此处我选择默认安装,继续点击【Next】按钮 (4)不选中,直接点击【Next】按钮 (5)点击【Install】按钮进行安装 (6)安装完毕,点击【Finish】按钮 (7)测试安装是否成功,按下【win+R】

By Ne0inhk