852. 山脉数组的峰顶索引


文章目录


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.代码

c++ 复制代码
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;
    }
};

相关推荐
灵感__idea2 小时前
Hello 算法:贪心的世界
前端·javascript·算法
澈2073 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
ambition202424 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
cmpxr_4 小时前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法
qiqsevenqiqiqiqi4 小时前
前缀和差分
算法·图论
代码旅人ing4 小时前
链表算法刷题指南
数据结构·算法·链表
Yungoal4 小时前
常见 时间复杂度计算
c++·算法
不爱吃炸鸡柳5 小时前
单链表专题(完整代码版)
数据结构·算法·链表
CylMK5 小时前
题解:AT_abc382_d [ABC382D] Keep Distance
算法
Dfreedom.6 小时前
计算机视觉全景图
人工智能·算法·计算机视觉·图像算法