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 小时前
进程的状态码
java·前端·算法
顾温4 小时前
default——C#/C++
java·c++·c#
凉茶钱4 小时前
【c语言】动态内存管理:malloc,calloc,realloc,柔性数组
c语言·c++·vscode·柔性数组
脏脏a4 小时前
【C++模版】泛型编程:代码复用的终极利器
开发语言·c++·c++模版
island13144 小时前
【C++仿Muduo库#3】Server 服务器模块实现上
服务器·开发语言·c++
散峰而望4 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
小龙报4 小时前
【C语言】内存里的 “数字变形记”:整数三码、大小端与浮点数存储真相
c语言·开发语言·c++·创业创新·学习方法·visual studio
躺不平的理查德4 小时前
时间复杂度与空间复杂度备忘录
数据结构·算法
yaki_ya4 小时前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
刃神太酷啦4 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode