162. 寻找峰值|刷题打卡

简介: 寻找峰值

一、题目描述:


峰值元素是指其值大于左右相邻值的元素。

给你一个输入数组 nums,找到峰值元素并返回其索引。数组可能包含多个峰值,在这种情况下,返回 任何一个峰值 所在位置即可。

你可以假设 nums[-1] = nums[n] = -∞ 。

示例 1:

输入:nums = [1,2,3,1]

输出:2

解释:3 是峰值元素,你的函数应该返回其索引 2。

示例 2:

输入:nums = [1,2,1,3,5,6,4]

输出:1 或 5

解释:你的函数可以返回索引 1,其峰值元素为 2;

或者返回索引 5, 其峰值元素为 6。

提示:
  • 1 <= nums.length <= 1000
  • -231 <= nums[i] <= 231 - 1
  • 对于所有有效的 i 都有 nums[i] != nums[i + 1]


二、思路分析:


思路一:

看到这个题目,第一想法就是使用循环,一个循环就能搞定。

一维数组,循环,取最大值即可。

思路二:

刚复习了一下二分查找,发现这题也可以使用二分查找来实现。

从中间开始查找,peakIndex为中间值,l为左边界,r为右边界值。判断nums[peakIndex] < nums[peakIndex + 1],符合条件则表示升序,nums[peakIndex + 1]大,那么就调整左边界为peakIndex + 1。如果不符合那就说明降序,nums[peakIndex]大,调整右边界。


三、AC 代码:


方法一:

function findPeakElement(nums: number[]): number {
    for (let i = 0; i < nums.length - 1; i++) {
        if (nums[i] > nums[i + 1])
            return i;
    }
    return nums.length - 1;
}


方法二:

function findPeakElement(nums: number[]): number {
  let l = 0;
  let r = nums.length - 1;
  let peakIndex;
  while (l <= r) {
    if (l === r) return l;
    peakIndex = Math.floor((l + r) / 2);
    if (nums[peakIndex] < nums[peakIndex + 1]) 
      l = peakIndex + 1;
      else r = peakIndex;
  }
}


四、总结:


此题求峰值,且返回符合条件的一种值就行,我们可以将其转为求最大值。特别要注意的是:在数组的最左边和最右边均为负无穷。


题目来源:leetcode。

本文正在参与「掘金 2021 春招闯关活动」, 点击查看 活动详情


作者:ClyingDeng

链接:https://juejin.cn/post/6935046069713813518

来源:稀土掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

目录
相关文章
|
10天前
|
算法
DAY-6 | 牛客-NC107 寻找峰值:二分法巧得峰值
这是一个关于寻找数组峰值的编程问题,题目来源于牛客网的 NC107 题目。文章介绍了两种方法,其中重点讲解了使用二分法寻找峰值的思路:通过比较数组中点与相邻元素的大小,不断缩小搜索范围,直到找到峰值或范围只剩一个元素。二分法的时间复杂度为 O(logN),空间复杂度为 O(1)。文章还配有多张图解和代码示例来辅助理解。
26 4
|
12天前
|
算法
【优选算法】——Leetcode——202—— 快乐数
【优选算法】——Leetcode——202—— 快乐数
【优选算法】——Leetcode——202—— 快乐数
|
20天前
每日一题(寻找奇数,寻找峰值)
每日一题(寻找奇数,寻找峰值)
12 0
|
6月前
【王道考研计算机网络】—时延、时延带宽积、RTT和利用率
【王道考研计算机网络】—时延、时延带宽积、RTT和利用率
|
6月前
|
算法 C语言 C++
LeetCode | 二叉树高频面试算法题汇总【速来】-2
LeetCode | 二叉树高频面试算法题汇总【速来】
39 0
|
6月前
|
算法 C语言 C++
LeetCode | 二叉树高频面试算法题汇总【速来】-1
LeetCode | 二叉树高频面试算法题汇总【速来】
37 0
|
Python
三年前写的文章,阅读量暴涨了6.8万。。。
三年前写的文章,阅读量暴涨了6.8万。。。
|
算法 搜索推荐 IDE
分享一个翻倍提升算法刷题通过率的技巧
今天就先来分享一个前期新手刷题的小技巧,能帮你减少代码提交次数,提升代码提交通过率。
193 0
|
存储 搜索推荐 算法
C++开发面试高频题目(建议收藏)
面向对象语言有三个最基本的特征就是:继承,多态, 封装。
|
算法 C语言 C++
LeetCode | 二叉树高频面试算法题汇总【速来】
🔥持续更新二叉树高频面试算法题,带你搞懂递归结构🔥
101 0
LeetCode | 二叉树高频面试算法题汇总【速来】