力扣162:寻找峰值

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

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

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

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

代码:

复制代码
int findPeakElement(int* nums, int numsSize){
    int low=0, high=numsSize-1, mid;

    while(low < high){
        mid = (low + high) / 2;         
        if(nums[mid] > nums[mid+1]){    //峰值为num[mid]或在num[mid]的左侧
            high = mid;
        }else{                          
            low = mid+1;
        }
    }

    return low;
}
相关推荐
蒲小英1 小时前
算法-使用技巧
算法
0x7F7F7F7F1 小时前
数学知识——博弈论
数学·算法
爱学习的小仙女!1 小时前
顺序表定义、特点和基本操作(含C代码详细讲解)及时间复杂度
数据结构·算法
芥子沫1 小时前
《人工智能基础》[算法篇5]:SVM算法解析
人工智能·算法·机器学习·支持向量机·svm
BigerBang1 小时前
LoRA 全方位指南:从底层原理到 Qwen-Image-Edit 实战
人工智能·pytorch·深度学习·算法
passxgx2 小时前
11.3 迭代法和预条件子
线性代数·算法·矩阵
TechPioneer_lp2 小时前
27届暑期实习内推:网易美团京东快手等
数据结构·c++·人工智能·笔记·机器学习·面试
X在敲AI代码2 小时前
【无标题】
算法·leetcode·职场和发展
bubiyoushang8882 小时前
NSGA-II 带精英策略的双目标遗传算法
算法
qq_430855882 小时前
线代第二章矩阵第八节逆矩阵、解矩阵方程
线性代数·算法·矩阵