206.贪心算法:摆动序列(力扣)

代码展示

cpp 复制代码
class Solution {
public:
    int wiggleMaxLength(vector<int>& nums) 
    {
        if (nums.size() <= 1) return nums.size();  // 如果数组长度小于等于1,返回数组长度

        int curdiff = 0;  // 当前元素和前一个元素的差值
        int prediff = 0;  // 前一个差值
        int result = 1;   // 最长摇摆子序列的长度,初始化为1,因为至少有一个元素

        for (int i = 0; i < nums.size() - 1; i++) 
        {
            curdiff = nums[i + 1] - nums[i];  // 计算当前元素和下一个元素的差值

            // 如果当前差值和前一个差值符号不同(包括第一次比较的情况),并且当前差值不为0
            if ((prediff <= 0 && curdiff > 0) || (prediff >= 0 && curdiff < 0)) 
            {
                result++;       // 摇摆子序列长度加1
                prediff = curdiff; // 更新前一个差值为当前差值
            }
        }

        return result;  // 返回最长摇摆子序列的长度
    }
};

代码核心思想

  1. 处理特殊情况

    • 如果数组长度小于等于1,直接返回数组长度,因为这种情况下,摇摆子序列的长度就是数组本身的长度。
  2. 初始化变量

    • curdiff:当前元素和前一个元素的差值。
    • prediff:前一个差值,用于记录上一次的差值。
    • result:结果,表示最长摇摆子序列的长度,初始值为1,因为至少有一个元素可以作为摇摆子序列的一部分。
  3. 遍历数组

    • 从数组的第一个元素开始,逐个计算当前元素和下一个元素的差值 (curdiff)。
    • 如果当前差值和前一个差值的符号不同(即一个正一个负),或者当前差值是第一个差值:
      • 增加结果 result 的值。
      • 更新前一个差值 prediff 为当前差值 curdiff
  4. 返回结果

    • 返回计算得到的最长摇摆子序列的长度。
相关推荐
春日见12 分钟前
控制算法:PP(纯跟踪)算法
linux·人工智能·驱动开发·算法·机器学习
智者知已应修善业16 分钟前
【编写函数求表达式的值】2024-4-3
c语言·c++·经验分享·笔记·算法
sinat_2869451928 分钟前
opencode
人工智能·算法·chatgpt
工口发动机44 分钟前
ABC440DEF简要题解
c++·算法
C++ 老炮儿的技术栈1 小时前
什么是通信规约
开发语言·数据结构·c++·windows·算法·安全·链表
零小陈上(shouhou6668889)1 小时前
K-近邻算法 - lazy learning的代表
算法·近邻算法
有一个好名字1 小时前
力扣-从字符串中移除星号
java·算法·leetcode
萧瑟其中~1 小时前
二分算法模版——基础二分查找,左边界查找与右边界查找(Leetcode的二分查找、在排序数组中查找元素的第一个位置和最后一个位置)
数据结构·算法·leetcode
码上就好ovo1 小时前
Atcoder Beginnner Contest 440
算法