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;
   }
相关推荐
Lee_yayayayaya2 分钟前
本原多项式产生m序列的原理
算法
许长安20 分钟前
c/c++ static关键字详解
c语言·c++·经验分享·笔记
Murphy_lx39 分钟前
C++ thread类
开发语言·c++
月夜的风吹雨40 分钟前
【C++ STL 深度剖析】:vector 底层模拟实现与核心陷阱解析
c++·vector·类和对象·visual studio
彩妙不是菜喵1 小时前
C++ 中 nullptr 的使用与实践:从陷阱到最佳实践
开发语言·jvm·c++
蒙奇D索大1 小时前
【算法】递归的艺术:从本质思想到递归树,深入剖析算法的性能权衡
经验分享·笔记·算法·改行学it
逐步前行1 小时前
C数据结构--排序算法
c语言·数据结构·排序算法
王哈哈^_^1 小时前
【数据集+完整源码】水稻病害数据集,yolov8水稻病害检测数据集 6715 张,目标检测水稻识别算法实战训推教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
light_in_hand1 小时前
内存区域划分——垃圾回收
java·jvm·算法
小安同学iter2 小时前
SQL50+Hot100系列(11.7)
java·算法·leetcode·hot100·sql50