从零学算法162

news/2024/7/24 5:50:51 标签: 算法, python, leetcode

162.峰值元素是指其值严格大于左右相邻值的元素。
给你一个整数数组 nums,找到峰值元素并返回其索引。数组可能包含多个峰值,在这种情况下,返回 任何一个峰值 所在位置即可。
你可以假设 nums[-1] = nums[n] = -∞ 。
你必须实现时间复杂度为 O(log 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。

  • 假设数组是一个递增的序列,当有递减趋势时就表示出现了一个峰值,nums[-1] = -∞,所以从 nums[0] 开始就符合递增特性
  •   public int findPeakElement(int[] nums) {
          int i = 0;
          while(i<nums.length-1 && nums[i+1]>nums[i])i++;
          return i;
      }
    
  • 上面的,时间复杂度为 O(N),不太行,由于不限制是第几个峰值,所以我们可以用二分查找使得时间复杂度为 O(lgN)
  •   public int findPeakElement(int[] nums) {
          int left = 0, right = nums.length - 1;
          while(left < right){
              int mid = left + (right - left) / 2;
              // 说明还是递增的趋势,递减趋势的值得往后找
              // 如果有递减的值那说明找到了峰值
              // 就算没有,那也说明这部分是递增序列,找到最后一个值就是最大值,一定为峰值
              if(nums[mid]<nums[mid+1])left = mid+1;
              // 有递减趋势,说明前半部分有峰值,同理
              // 就算前半部分一直是递减的,也有 nums[0] 保底
              else right = mid;
          }
          return left;
      }
    

http://www.niftyadmin.cn/n/5369011.html

相关文章

1795. 每个产品在不同商店的价格

说在前面 &#x1f388;不知道大家对于算法的学习是一个怎样的心态呢&#xff1f;为了面试还是因为兴趣&#xff1f;不管是出于什么原因&#xff0c;算法学习需要持续保持。 题目描述 表&#xff1a;Products ---------------------- | Column Name | Type | ------------…

Nginx中logs的nginx.pid文件引发的问题

Nginx中logs的nginx.pid文件引发的问题 Q1&#xff1a;nginx: [error] CreateFile() "D:\software\nginx-1.22.1/logs/nginx.pid" failed (2: The system cannot find the file specified)Q2&#xff1a;nginx: [error] invalid PID number "" in "D:…

记录 | .ui转.py

方法一&#xff1a;直接使用命令行 python -m PyQt5.uic.pyuic xx.ui -o xx.py 方法二&#xff1a;直接使用命令 先进到 C:\python\pkgs\pyqt-5.9.2-py37h6538335_2\Library\bin 里面 然后执行 pyuic5 在anaconda的pkg里面 pyuic5 pyqt5_01.ui -o pyqt5_01_ui.py 方法三…

(c语言版)数组去重和排序 题目描述: 给定一个乱序的数组,删除所有的重复元素,使得每个元素只出现一次,并且按照出现的次数从高到低

【编程题目 | 100分】数组去重和排序 [ 100 / 中等 ] 数组去重和排序 题目描述&#xff1a; 给定一个乱序的数组&#xff0c;删除所有的重复元素&#xff0c;使得每个元素只出现一次&#xff0c;并且按照出现的次数从高到低进行排序&#xff0c;相同出现次数按照第一次出现顺序…

NLP中的嵌入和距离度量

本文将深入研究嵌入、矢量数据库和各种距离度量的概念&#xff0c;并提供示例和演示代码。 NLP中的嵌入 嵌入是连续向量空间中对象、单词或实体的数值表示。在NLP中&#xff0c;词嵌入捕获词之间的语义关系&#xff0c;使算法能够更好地理解文本的上下文和含义。 让我们试着用…

CTFshow web(php命令执行 37-40)

?ceval($_GET[shy]);&shypassthru(cat flag.php); #逃逸过滤 ?cinclude%09$_GET[shy]?>&shyphp://filter/readconvert.base64-encode/resourceflag.php #文件包含 ?cinclude%0a$_GET[cmd]?>&cmdphp://filter/readconvert.base64-encode/…

【MySQL】MySQL复合查询--多表查询/自连接/子查询

文章目录 1.基本查询回顾2.多表查询3.自连接4.子查询4.1单行子查询4.2多行子查询4.3多列子查询4.4在from子句中使用子查询4.5合并查询4.5.1 union4.5.2 union all 1.基本查询回顾 表的内容如下&#xff1a; mysql> select * from emp; ----------------------------------…

张艺谋《主角》选角引发热议,周迅、赵丽颖、杨紫或成候选。

♥ 为方便您进行讨论和分享&#xff0c;同时也为能带给您不一样的参与感。请您在阅读本文之前&#xff0c;点击一下“关注”&#xff0c;非常感谢您的支持&#xff01; 文 |猴哥聊娱乐 编 辑|徐 婷 校 对|侯欢庭 近日&#xff0c;张艺谋执导的首部电视剧《主角》女主选角成为…