力扣-贪心-376 摆动序列

思路

记录前一个差值和后一个差值,需要分析很多情况

  1. 只有在发生波动的时候才更新差值------单调中有平坡
  2. 前一个差值==0时也更新差值------平坡留下最左边元素
  3. 最后一个元素不记录.默认从最后一个有坡度

代码

cpp 复制代码
class Solution {
public:
    int wiggleMaxLength(vector<int>& nums) {
        int res = 1;
        int preDiff = 0;
        for(int i = 0; i < nums.size() - 1; i++){
            int curDiff = nums[i + 1] - nums[i];
            if(preDiff <= 0 && curDiff > 0 || preDiff >= 0 && curDiff < 0){
                res++;
                preDiff = curDiff;
            }
        }

        return res;
    }
};
相关推荐
feifeigo1237 分钟前
Matlab编写压缩感知重建算法集
人工智能·算法·matlab
烛衔溟39 分钟前
C语言多级指针与函数指针:指针的高级用法
c语言·算法
Sunhen_Qiletian1 小时前
YOLOv2算法详解(下篇):细节打磨与性能突破的终极密码
算法·yolo
wefg13 小时前
【数据结构】unordered 系列容器底层结构和封装
数据结构·算法·哈希算法
从零点3 小时前
插补算法(逐点比较法)+PWM配置操作
算法
DARLING Zero two♡3 小时前
【优选算法】LinkedList-Concatenate:链表的算法之契
数据结构·c++·算法·链表
Moonbit3 小时前
MoonBit Pearls Vol.14:哈希表避坑指南
后端·算法·编程语言
杰克尼3 小时前
120. 三角形最小路径和
算法
树在风中摇曳4 小时前
C语言动态内存管理:从基础到进阶的完整解析
c语言·开发语言·算法