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;
   }
相关推荐
感哥36 分钟前
C++ std::set
c++
Fanxt_Ja1 小时前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
侃侃_天下1 小时前
最终的信号类
开发语言·c++·算法
茉莉玫瑰花茶1 小时前
算法 --- 字符串
算法
博笙困了1 小时前
AcWing学习——差分
c++·算法
NAGNIP1 小时前
认识 Unsloth 框架:大模型高效微调的利器
算法
NAGNIP1 小时前
大模型微调框架之LLaMA Factory
算法
echoarts1 小时前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Python技术极客2 小时前
一款超好用的 Python 交互式可视化工具,强烈推荐~
算法
徐小夕2 小时前
花了一天时间,开源了一套精美且支持复杂操作的表格编辑器tablejs
前端·算法·github