当前位置: 首页 > article >正文

852. 山脉数组的峰顶索引


文章目录

  • 1.题目
  • 2.思路
  • 3.代码


1.题目

852. 山脉数组的峰顶索引

给定一个长度为 n 的整数 山脉 数组 arr ,其中的值递增到一个 峰值元素 然后递减。

返回峰值元素的下标。

你必须设计并实现时间复杂度为 O(log(n)) 的解决方案。

示例 1:

输入:arr = [0,1,0]
输出:1

示例 2:

输入:arr = [0,2,1,0]
输出:1

示例 3:

输入:arr = [0,10,5,2]
输出:1

2.思路

通过比较中间元素 nums[mid] 和其右侧元素 nums[mid + 1],如果 nums[mid] < nums[mid + 1],说明峰值在右侧,因此移动左指针;否则,峰值在左侧或当前中间元素处,因此移动右指针。最终,当左右指针相遇时,左指针的位置即为山脉数组的峰值索引。

3.代码

class Solution {
public:
    int peakIndexInMountainArray(vector<int>& nums) {
        // 初始化左右指针,left 指向数组的起始位置,right 指向数组的末尾
        int left = 0, right = nums.size() - 1;
        
        // 使用二分查找法,在左右指针重合之前不断缩小查找范围
        while (left <= right) {
            // 计算中间位置,避免直接相加可能导致整数溢出
            int mid = left + (right - left) / 2;
            
            // 如果中间位置的元素小于其右边的元素,说明峰值在右侧
            if (nums[mid] < nums[mid + 1]) {
                left = mid + 1;  // 将左指针移动到 mid 的右侧
            } else {
                // 否则,说明峰值可能在 mid 或其左侧
                right = mid - 1; // 将右指针移动到 mid 的左侧
            }
        }
        
        // 当循环结束时,left 指向的就是峰值所在的索引
        return left;
    }
};


http://www.kler.cn/news/336414.html

相关文章:

  • 计算机网络自顶向下(2)----socket编程
  • 分享国产32位单片机的电机控制方案
  • GEE 土地分类:利用Landsat C02 TOA数据进行土地分类精度超95%(希腊雅典为例)并监测不同年份的绿地面积
  • Android高级控件
  • (2025)408考研:王道操作系统文件管理强化
  • Sublime Text 下载地址分享
  • 看480p、720p、1080p、2k、4k、视频一般需要多大带宽呢?
  • 信息学奥赛使用的编程IDE:Dev-C++ 安装指南
  • Linux之进程概念
  • 毕业设计 深度学习昆虫识别系统(源码+论文)
  • Kafka的基本概念整理
  • UE5蓝图实战:打造自定义摄像机视野控制
  • 排序算法总结(含链表)
  • 民峰:为投资者提供稳健的财富管理方案
  • 鸿蒙开发(NEXT/API 12)【二次向用户申请授权】程序访问控制
  • 秋招内推2025-招联金融
  • 基于opencv-C++dnn模块推理的yolov5 onnx模型
  • King3399 SDK(ubuntu文件系统)编译简明教程
  • 我的笔记本电脑之前可以直接用音量键调节音量,后来需要fn键加音量键才能调节,这是为什么?
  • 【Spring】Spring MVC的项目准备和连接建立