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;
    }
};

相关推荐
yong99901 天前
MATLAB面波频散曲线反演程序
开发语言·算法·matlab
JicasdC123asd1 天前
【工业检测】基于YOLO13-C3k2-EIEM的铸造缺陷检测与分类系统_1
人工智能·算法·分类
Not Dr.Wang4221 天前
自动控制系统稳定性研究及判据分析
算法
VT.馒头1 天前
【力扣】2722. 根据 ID 合并两个数组
javascript·算法·leetcode·职场和发展·typescript
ffqws_1 天前
A*算法:P5507 机关 题解
算法
执着2591 天前
力扣hot100 - 108、将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
2501_901147831 天前
学习笔记:单调递增数字求解的迭代优化与工程实践
linux·服务器·笔记·学习·算法
AI科技星1 天前
张祥前统一场论核心场方程的经典验证-基于电子与质子的求导溯源及力的精确计算
线性代数·算法·机器学习·矩阵·概率论
kebijuelun1 天前
ERNIE 5.0:统一自回归多模态与弹性训练
人工智能·算法·语言模型·transformer
历程里程碑1 天前
普通数组----最大子数组和
大数据·算法·elasticsearch·搜索引擎·排序算法·哈希算法·散列表