Cool说丨力扣162

简介: 162. 寻找峰值


162. 寻找峰值

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

给定一个输入数组 nums,其中 nums[i] ≠ nums[i+1],找到峰值元素并返回其索引。

数组可能包含多个峰值,在这种情况下,返回任何一个峰值所在位置即可。

你可以假设 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。

第一版,直接暴力法

执行用时 :8 ms, 在所有 C++ 提交中击败了73.77%的用户

内存消耗 :8.7 MB, 在所有 C++ 提交中击败了69.45%的用户

   intfindPeakElement(vector<int>&nums) {

   if (nums.size() <=1) return0;

   if (nums[1] <nums[0]) return0;

   if (nums[nums.size() -2] <nums[nums.size() -1]) returnnums.size() -1;

   inttemp=0;

   for (inti=1; i<=nums.size() -2;++i) {

       if(nums[i]>nums[i-1] &&  nums[i]>nums[i+1]) returni;

   }

   return0;

   }

第二版 二分法模板

low<=high

low=mid+1;

high=mid-1;

结束时,low在high前面一个元素了,差值为0和1时都会继续执行,需要注意边界问题

   intfindPeakElement(vector<int>&nums) {

   if (nums.size() <=1) return0;

   if (nums[0] >nums[1]) {

       return0;

   }

   if (nums[nums.size() -1] >nums[nums.size() -2]) {

       returnnums.size() -1;

   }

   intl=0,r=nums.size() -1;

   while (l  <=r) {

       intm= (l+r) /2;

       if (m>0andnums[m-1] >nums[m]) {

           r=m-1;

       }

       elseif (m<nums.size() andnums[m+1] >nums[m]) {

           l=m+1;

       }

       else {

           returnm;

       }

   }

   returnl;

   }


目录
相关文章
|
人工智能 C# C++
Cool说丨力扣153、454
153. 寻找旋转排序数组中的最小值 454. 四数相加 II
138 1
|
C# C++
Cool说丨力扣287/792/378
关注博主,获取更多知识
115 0
|
存储 C# C++
Cool说丨力扣29/34
关注博主。获取更多知识
116 0
|
存储 C# C++
Cool说丨力扣392
392. 判断子序列
80 0
|
C# C++
Cool说丨力扣744、704
744. 寻找比目标字母大的最小字母 704. 二分查找
113 0
|
C#
Cool说丨力扣475
475. 供暖器
121 0
|
机器学习/深度学习 算法 C#
Cool说丨力扣202
202. 快乐数
105 0
|
C#
Cool说丨力扣167
167. 两数之和 II - 输入有序数组
76 0
|
C# C++
Cool说丨力扣374、441
441. 排列硬币 374. 猜数字大小
101 0
|
C# C++
Cool说丨力扣367
367. 有效的完全平方数
262 0