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

LeetCode、162. 寻找峰值【中等,最大值、二分】

文章目录

  • 前言
  • LeetCode、162. 寻找峰值【中等,最大值、二分】
    • 题目及类型
    • 思路及代码
      • 思路1:二分
      • 思路2:寻找最大值
  • 资料获取

前言

博主介绍:✌目前全网粉丝2W+,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技术领域。

涵盖技术内容:Java后端、算法、分布式微服务、中间件、前端、运维、ROS等。

博主所有博客文件目录索引:博客目录索引(持续更新)

视频平台:b站-Coder长路


LeetCode、162. 寻找峰值【中等,最大值、二分】

来源:LeetCode专题《LeetCode 75》

题目及类型

题目地址:LeetCode、162. 寻找峰值

题目类型:基础算法/二分

题目描述:给定一个长度为n的数组nums,请你找到峰值并返回其索引。数组可能包含多个峰值,在这种情况下,返回任何一个所在位置即可。

1.峰值元素是指其值严格大于左右相邻值的元素。严格大于即不能有等于
2.假设 nums[-1] = nums[n] = -\infty−∞
3.对于所有有效的 i 都有 nums[i] != nums[i + 1]
4.你可以使用O(logN)的时间复杂度实现此问题吗?

思路及代码

思路1:二分

思路说明:拆分范围

由于题目假设 nums[-1] = nums[n] = -∞ ,那么我们一定能够找到一个峰值元素。

  • nums[mid] > nums[mid + 1] [l, mid]
  • nums[mid] < nums[mid + 1] [mid + 1, r]

由于没有r = mid - 1情况,那么我们无需进行(l + r + 1) / 2

复杂度分析:

  • 时间复杂度:O(logn)
  • 空间复杂度:O(1)

image-20240119215046211

class Solution {//二分//元素值是int最大值//边界值无需处理//nums[mid] > nums[mid + 1]  [l, mid]     nums[mid] < nums[mid + 1] [mid + 1, r]public int findPeakElement(int[] nums) {int l = 0, r = nums.length - 1;while (l < r) {int mid = l + r >> 1;if (nums[mid] > nums[mid + 1]) {r = mid;}else {l = mid + 1;}}return l;}
}

思路2:寻找最大值

复杂度分析:时间复杂度O(n),空间复杂度O(1)

class Solution {//找到最大值索引public int findPeakElement(int[] nums) {int max = 0; for (int i = 1; i < nums.length; i ++) {if (nums[max] < nums[i]) {max = i;}}return max;}
}

image-20240119215549385


资料获取

大家点赞、收藏、关注、评论啦~

精彩专栏推荐订阅:在下方专栏👇🏻

  • 长路-文章目录汇总(算法、后端Java、前端、运维技术导航):博主所有博客导航索引汇总
  • 开源项目Studio-Vue—校园工作室管理系统(含前后台,SpringBoot+Vue):博主个人独立项目,包含详细部署上线视频,已开源
  • 学习与生活-专栏:可以了解博主的学习历程
  • 算法专栏:算法收录

更多博客与资料可查看👇🏻获取联系方式👇🏻,🍅文末获取开发资源及更多资源博客获取🍅


整理者:长路 整理时间:2024.1.19

相关文章:

  • 5. UE5 RPG使用GAS技能系统
  • vue中改变v-html中包含body标签的样式修改方法
  • 鸿蒙开发环境配置-Windows
  • cherry键盘alt+tab无法切换窗口的问题解决
  • HTML 列表 iframe
  • H12-821_324
  • 免费开源OCR 软件Umi-OCR
  • 《2023中国低代码商业落地研究报告》
  • Android 系统启动过程纪要(基于Android 10)
  • 基于FPGA的图像双边滤波实现,包括tb测试文件和MATLAB辅助验证
  • 计算机找不到msvcp120.dll的修复方法,总结五种可靠的方法
  • 使用延迟队列处理超时订单
  • 【算法练习】leetcode算法题合集之栈和队列篇
  • 安卓、ios系统详解
  • 黑马程序员 Java设计模式学习笔记(一)
  • 0基础学习移动端适配
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • Javascript 原型链
  • java小心机(3)| 浅析finalize()
  • JS题目及答案整理
  • JWT究竟是什么呢?
  • mysql innodb 索引使用指南
  • overflow: hidden IE7无效
  • Terraform入门 - 1. 安装Terraform
  • vue从创建到完整的饿了么(18)购物车详细信息的展示与删除
  • 从@property说起(二)当我们写下@property (nonatomic, weak) id obj时,我们究竟写了什么...
  • 给github项目添加CI badge
  • 构造函数(constructor)与原型链(prototype)关系
  • 关于extract.autodesk.io的一些说明
  • 开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
  • 聊聊springcloud的EurekaClientAutoConfiguration
  • 如何进阶一名有竞争力的程序员?
  • 入门到放弃node系列之Hello Word篇
  • 算法-图和图算法
  • 在weex里面使用chart图表
  • 自制字幕遮挡器
  • 函数计算新功能-----支持C#函数
  • 直播平台建设千万不要忘记流媒体服务器的存在 ...
  • # include “ “ 和 # include < >两者的区别
  • #宝哥教你#查看jquery绑定的事件函数
  • #传输# #传输数据判断#
  • #每天一道面试题# 什么是MySQL的回表查询
  • (10)工业界推荐系统-小红书推荐场景及内部实践【排序模型的特征】
  • (C++20) consteval立即函数
  • (附源码)node.js知识分享网站 毕业设计 202038
  • (机器学习-深度学习快速入门)第三章机器学习-第二节:机器学习模型之线性回归
  • (使用vite搭建vue3项目(vite + vue3 + vue router + pinia + element plus))
  • (一)Dubbo快速入门、介绍、使用
  • (一)搭建springboot+vue前后端分离项目--前端vue搭建
  • (转)Oracle存储过程编写经验和优化措施
  • (转)总结使用Unity 3D优化游戏运行性能的经验
  • 、写入Shellcode到注册表上线
  • .babyk勒索病毒解析:恶意更新如何威胁您的数据安全
  • .NET Framework Client Profile - a Subset of the .NET Framework Redistribution
  • .NET gRPC 和RESTful简单对比