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

文章目录

前言

博主介绍:✌目前全网粉丝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)
java 复制代码
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)

java 复制代码
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;
    }
}

资料获取

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

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

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


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

相关推荐
No0d1es6 小时前
电子学会青少年软件编程(C/C++)5级等级考试真题试卷(2024年6月)
c语言·c++·算法·青少年编程·电子学会·五级
大阳1238 小时前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验
Swift社区9 小时前
Swift 实战:实现一个简化版的 Twitter(LeetCode 355)
leetcode·swift·twitter
weixin_3077791310 小时前
VS Code配置MinGW64编译GNU 科学库 (GSL)
开发语言·c++·vscode·算法
学行库小秘10 小时前
ANN神经网络回归预测模型
人工智能·python·深度学习·神经网络·算法·机器学习·回归
没落之殇10 小时前
基于C语言实现的HRV分析方法 —— 与Kubios和MATLAB对比
算法
秋难降10 小时前
线段树的深度解析(最长递增子序列类解题步骤)
数据结构·python·算法
楚韵天工11 小时前
基于GIS的无人机模拟飞行控制系统设计与实现
深度学习·算法·深度优先·无人机·广度优先·迭代加深·图搜索算法
你也向往长安城吗12 小时前
推荐一个三维导航库:three-pathfinding-3d
javascript·算法
百度智能云12 小时前
VectorDB+FastGPT一站式构建:智能知识库与企业级对话系统实战
算法