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)

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


资料获取

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

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

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


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

相关推荐

  1. Leetcode 152. 乘积子数组和Leetcode 162. 寻找峰值

    2024-01-21 00:20:03       42 阅读
  2. LeetCode162. 寻找峰值

    2024-01-21 00:20:03       40 阅读
  3. LeetCode 162. 寻找峰值

    2024-01-21 00:20:03       26 阅读
  4. LeetCode每日一题.08(162.寻找峰值)

    2024-01-21 00:20:03       50 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-21 00:20:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-21 00:20:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-21 00:20:03       82 阅读
  4. Python语言-面向对象

    2024-01-21 00:20:03       91 阅读

热门阅读

  1. 力扣54. 螺旋矩阵

    2024-01-21 00:20:03       68 阅读
  2. logback日志记录器

    2024-01-21 00:20:03       58 阅读
  3. C# 十大排序算法

    2024-01-21 00:20:03       51 阅读
  4. 第二章 变量与基本类型(上)

    2024-01-21 00:20:03       46 阅读
  5. 在vue中如何优雅的封装第三方组件

    2024-01-21 00:20:03       76 阅读
  6. 【Effective C++】让自己习惯C++

    2024-01-21 00:20:03       58 阅读
  7. 关于Qt Creator 的项目创建

    2024-01-21 00:20:03       64 阅读
  8. 10 快速排序-左右指针法

    2024-01-21 00:20:03       57 阅读
  9. 根据自己修改后的容器制作镜像并上传docker hub

    2024-01-21 00:20:03       49 阅读
  10. wpf C# partial关键字:把一个类分成几个

    2024-01-21 00:20:03       66 阅读