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;
   }
相关推荐
自我意识的多元宇宙4 小时前
树与二叉树--二叉树的存储结构
数据结构
BestOrNothing_20156 小时前
C++零基础到工程实战(4.3.3):vector数组访问与遍历
c++·迭代器·stl·vector·动态数组
charlie1145141916 小时前
通用GUI编程技术——图形渲染实战(三十三)——Direct2D与Win32/GDI互操作:渐进迁移实战
c++·图形渲染·gui·win32
文祐6 小时前
C++类之虚函数表及其内存布局(一个子类继承一个父类)
开发语言·c++
白羊by6 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
墨尘笔尖7 小时前
最大最小值降采样算法的优化
c++·算法
自我意识的多元宇宙9 小时前
二叉树的遍历和线索二叉树--二叉树的遍历
数据结构
YIN_尹9 小时前
【Linux系统编程】进程地址空间
linux·c++
qq_5024289909 小时前
清华大学与微软亚洲研究院出品:Kronos 本地部署教程
数据结构·python·金融量化·kronos开源模型
EverestVIP9 小时前
C++中空类通常大小为1的原理
c++