leetcode 162 寻找峰值

直观解法1:遍历 算法复杂度O(n)

cpp 复制代码
int findPeakElement(vector<int>& nums) {
        int size = nums.size();
        //一个元素,直接返回0
        if(size == 1) return 0;
        //两个元素,返回最大的idx
        if(size == 2) 
        {
            if(nums[0] > nums[1]) 
                return 0;
            else 
                return 1;
        }
        int max_val = nums[0];
        int idx = 0; 
        int i = 0;
        //遍历,同时记录最大值和最大值idx
        for(;i + 2 < size - 1; i++)
        {
            if(nums[i] > max_val)
            {
                max_val = nums[i];
                idx = i;
            }
            //如果遇到一个波峰,返回idx
            if(nums[i] < nums[i+1] && nums[i+1] > nums[i+2]) 
                return i+1;
        }
        //遍历最后两个,记录最大值的idx
        if(max_val < nums[i+1])
        {
            max_val = nums[i+1];
            idx = i+1;
        }
        if(max_val < nums[i+2])
        {
            max_val = nums[i+2];
            idx = i+2;
        }
        //返回最大值的idx
        return idx;
    }

解法2:题目要求O(logn),那肯定是二分查找了

cpp 复制代码
int findPeakElement(vector<int>& nums){
        //单元素,直接返回
        if(nums.size() == 1) return 0;
        int l = 0, r = nums.size()-1, mid;
        while(l < r)
        {
            mid = (l + r) / 2;
            // r-l=1的情况
            if(mid == l) return nums[mid] > nums[r] ? mid : r;
            if(mid == r) return nums[mid] > nums[l] ? mid : l;
            //波峰
            if(nums[mid] > nums[mid-1] && nums[mid] > nums[mid+1])
                return mid;
            if(nums[mid] < nums[mid-1])
            {
                r = mid - 1;
                //这个不能少,我们只需要判断大的一侧就行
                continue;
            }
            if(nums[mid] < nums[mid+1])
            {
                l = mid + 1;
            }
        }
        return (l+r)/2;
   }
相关推荐
汀小烟5 分钟前
使用静态成员函数统计学生平均成绩
c语言·开发语言·数据结构·c++·vscode
LeoLei80601 小时前
新特性之C++17
开发语言·c++
Ezekiel Mok1 小时前
基于路径长度的样条插补算法(自动驾驶和路径跟踪控制适用)
算法·matlab·自动驾驶·路径跟踪·插补
jllws12 小时前
C++基础:STL概述
开发语言·c++
FightingLod2 小时前
C++中list容器使用详解
开发语言·c++·list
yyqzjw2 小时前
【C++】单例模式
c++·单例模式
mana飞侠2 小时前
代码随想录算法训练营第59天:动态[1]
开发语言·数据结构·算法·动态规划
每天的积累2 小时前
C++学习笔记二
c++·笔记·学习
zengy52 小时前
代码随想录打卡第十三天
数据结构·c++·算法·leetcode
野草y2 小时前
数据结构(3.2)——栈的顺序存储实现
数据结构