当前位置: 首页 > news >正文

leetcode 162. Find Peak Element

题目描述

如果nums[i-1]<nums[i]并且nums[i]>nums[i+1],那么nums[i]就是峰值。除此情况之外,nums[i-1]和nums[i+1]至少有一个大于nums[i],因为题目已经保证相邻的元素不相等。坚持向上坡方向走一定能达到一个峰值,如果往两边走都是上坡,那就随意向两边选一个方向走。

class Solution {
public:int findPeakElement(vector<int>& nums) {int left = 0;int right = nums.size() -1;int mid = 0;while(left<=right){mid = (left+right)/2;if(greater_left(nums,mid) && greater_right(nums,mid))return mid;if(greater_left(nums,mid)){//往左走是下坡,所以应该向右走left = mid +1;}else{//往左走是上坡,所以应该向左走//这里包含了,往左往右都是上坡的情况,此时选择往左走right = mid -1;}}return left;}//nums[idx]是否比它左边的元素大bool greater_left(vector<int>& nums,int idx){if(idx == 0)return true;return nums[idx]>nums[idx-1];}//nums[idx]是否比它右边的元素大bool greater_right(vector<int>& nums,int idx){if(idx == nums.size() -1)return true;return nums[idx]>nums[idx+1];}
};
http://www.xdnf.cn/news/557353.html

相关文章:

  • python新手学习笔记①
  • Linux探秘:驾驭开源,解锁高效能——基础指令
  • Git命令使用全攻略:从创建分支到合并的完整流程
  • 大模型高效微调技术全面解析:从PEFT原理到实战应用
  • 项目进度延误,如何按时交付?
  • 预训练模型:深度学习的通用特征引擎
  • Greenplum数据库维护篇之常用操作指导
  • TripGenie:畅游济南旅行规划助手:个人工作纪实(十八)
  • Windows逆向工程提升之IMAGE_DOS_HEADER
  • 定时任务延迟任务
  • linux内核编译学习笔记
  • Java异常处理与File类终极指南
  • 【基础知识】SPI协议的种类及异同
  • 数据库 1.0.1
  • DAY28类
  • MYSQL备份恢复知识:第四章:备份锁
  • 【优秀三方库研读】在 quill 开源库中为什么封装 safe_fwrite,而不是直接使用系统 fwrite
  • MySQL中添加一个具有创建数据库权限的用户
  • Java并发进阶系列:深度讨论jdk1.8 ConcurrentHashMap并发环境下transfer方法桶位分配过程
  • C/C++ Select Poll Epoll 多路转接
  • python -> matplotlib简单用法
  • Unity3D仿星露谷物语开发47之砍树时落叶特效
  • Wan2.1 加速推理方法
  • 使用cursor自动生成前后端分离的web应用程序
  • ROS2 pkg 创建功能包
  • [ 计算机网络 ] 深入理解OSI七层模型
  • 经验过程简介与suprema的集中(Guntuboyina理论统计学笔记)
  • QT高DPI支持
  • linux之 pcie MSI-X中断编程
  • 自动化测试核心知识梳理与 Java 代码详解