【算法详解】力扣162.寻找峰值


目录

  • 一、题目描述
  • 二、思路分析

一、题目描述

力扣链接:力扣162.寻找峰值

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

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

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

你必须实现时间复杂度为 O(log n) 的算法来解决此问题。

二、思路分析

最简单的方法,直接使用std::max_element()寻找最大值,最大值一定是一个峰值。

class Solution {
public:int findPeakElement(vector<int>& nums) {return max_element(nums.begin(), nums.end()) - nums.begin();}
};

该方法是时间复杂度为O(N),题目要求O(logN),查找算法容易想到的是二分查找,该题也可以使用二分查找方法来求解。

二分查找的核心是当中间值满足条件时,就可以舍弃另一半,从而缩小范围。

题目中说可以假设 nums[-1] = nums[n] = -∞ 。那么说明首个元素nums[0]和最后一个元素nums[n-1]也可以是峰值。

那么对于二分查找的mid

  • 大于右边的值,那么左边一定有峰值;
  • 在这里插入图片描述
  • 反之,则右边一定有峰值
  • 在这里插入图片描述

因此可以写出以下代码:

class Solution {
public:int findPeakElement(vector<int>& nums) {int n = nums.size();int left = 0, right = n - 1;while (left < right) {int mid = (left + right) >> 1; // 右移一位,相当于除以2if (nums[mid] > nums[mid + 1]) {right = mid;}else {left = mid + 1;}}return left;}
};

求解完毕。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/417937.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

cetos7搭建部署k8s 版本1.28

主机分配 内存最少是4G cpu个数最少两个 IP内存CPU主机名192.168.231.12044K1 192.168.231.12144K2192.168.231.12244K3 关闭防火墙 systemctl stop firewalled 关闭swap vim /etc/fstab 设置主机名称 hostnameset 安装docker 三个主机 初始化集群 在mas…

机器学习之聚类-2D数据类别划分

无监督学习&#xff08;Unsupervised Learning&#xff09; 机器学习的一种方法&#xff0c;没有给定事先标记过的训练示例&#xff0c;自动对输入的数据进行分类或分群。 方式一&#xff1a;站着或坐着 方式二&#xff1a;全身或半身 方式三&#xff1a;蓝眼球或不是蓝眼球 …

CVE-2023-46226 Apache iotdb远程代码执行漏洞

项目介绍 Apache IoTDB 是针对时间序列数据收集、存储与分析一体化的数据管理引擎。它具有体量轻、性能高、易使用的特点&#xff0c;完美对接 Hadoop 与 Spark 生态&#xff0c;适用于工业物联网应用中海量时间序列数据高速写入和复杂分析查询的需求。 项目地址 https://io…

Leetcode刷题-(6~10)-Java+Python+JavaScript

算法题是程序员的基本功&#xff0c;也是各个大厂必考察的重点&#xff0c;让我们一起坚持写算法题吧 遇事不决&#xff0c;可问春风&#xff0c;春风不语&#xff0c;即是本心。 我们在我们能力范围内&#xff0c;做好我们该做的事&#xff0c;然后相信一切都事最好的安排就…

python代码的保护之Pyarmor(一)

我们在用python程序开发完程序后&#xff0c;进行程序发布。发布后要保证算法的安全性&#xff0c;常常需要对代码进行保护&#xff0c;通过这段时间的搜集整理&#xff0c;目前常见的保护方式有&#xff1a;代码混淆加密、编译成二进制动态库、 本篇讲述Pyarmor加密 参考链接&…

Java 面向对象02 封装 (黑马)

人画圆&#xff1a;画圆这个方法应该定义在园这个类里面。 人关门&#xff1a;是人给了门一个作用力&#xff0c;然后门自己关上了门&#xff0c;所以关门的方法是在门的类里面 封装对象的好处&#xff1a; 调用Java自带的方法举例实现&#xff1a; 在测试类中&#xff0c;对其…

聊一聊 C# 的线程本地存储TLS到底是什么

一&#xff1a;背景 1. 讲故事 有朋友在后台留言让我说一下C#的 ThreadStatic 线程本地存储是怎么玩的&#xff1f;这么说吧&#xff0c;C#的ThreadStatic是假的&#xff0c;因为C#完全是由CLR&#xff08;C&#xff09;承载的&#xff0c;言外之意C#的线程本地存储&#xff…

长风破浪会有时

工作半年了&#xff0c;实际的工作体验跟当初想象的好像是不太一样。感觉还是在学校读书好啊 方向&#xff1f; 半年没更了&#xff0c;偶尔也有些网友私信问我DSP相关的问题&#xff0c;但是我现在也没有继续做DSP了&#xff0c;很多也都忘了&#xff0c;所以可能帮不上什么…

linux第一个小程序 --- 进度条【简洁】

行缓冲区的概念 结果&#xff1a;先输入hello world然后休眠三秒后结束 当去掉’\n“ 后&#xff0c;结果就变成了先休眠三秒&#xff0c;然后打印hello world后结束。 该现象就证明了缓冲区的存在。 当缓冲区中遇到’‘\n’或者缓冲区被写满后才会被打印出来&#xff0c;在第…

Rust、Go、C ,哪个才是“内存管理大师”?

编程语言各有各的“大能”&#xff0c;但如果谈到内存管理&#xff0c;Rust的话语权不是一般的高。GC&#xff08;垃圾回收&#xff09;&#xff1f;手动分配&#xff1f;对于掌握了Rust奥义的开发者而言&#xff0c;这些词汇简直弱爆了。众所周知&#xff0c;Rust编程语言的主…

nginx基本优化

1、安装nginx隐藏版本号 1.1、查看百度web服务器 [rootcjq11 ~]# curl -I http://www.baidu.com 1.2、隐藏nginx服务器版本号 [rootcjq11 ~]# cd /usr/local/src/nginx-1.22.0/ [rootcjq11 nginx-1.22.0]# vim src/core/nginx.h第13、14行修改版本号和服务器名称 [rootcj…

洛谷P5732 【深基5.习7】杨辉三角(C语言)

入门递推题&#xff0c;就算你不是OIer也该知道的杨辉三角 同时这也是组合数的公式&#xff0c;很重要&#xff0c;因为常规组合数公式是阶乘运算会爆&#xff0c;而这个就不怎么会了 赋 arr[i][j]初值1&#xff0c;接下来就可以递推了 #include<stdio.h> int main() …