当前位置: 首页 > news >正文

动态规划-376.摆动序列-力扣(LeetCode)

一、题目解析

看着题目上的解释或许有点难以理解,这里一图流

 

只要形似上图的都可以是摆动序列,如左图,且仅含一个元素和两个元素的也算摆动序列,如右图 

二、算法原理

1、状态表示

根据经验我们都是以i位置为结尾时,最长摆动子序列的长度

但是根据我们下面的题目分析,我们可以知道最后一个位置存在两种情况

f[i]表示:以i位置为结尾时,最后一个呈“上升”趋势的,最长摆动子序列

g[i]表示:一i位置为结尾时,最后一个呈“下降”趋势的,最长摆动子序列

2、状态转移方程

f[i]是以上升为结尾,所以前一个状态为下降

f[i]->长度为1时->f[i]=1

f[i]->长度大于1是->nums[j]<nums[i],j属于[0,i-1]->f[i]=max(g[j]+1,f[i])

g[i]同理,前一个状态为上升

g[i]->长度为1时->g[i]=1

g[i]->长度大于1是->nums[j]>nums[i],j属于[0,i-1]->g[i]=max(f[j]+1,g[i])

3、初始化

由于最坏的情况下,所有子序列都为1,所以可以将f、g表内的值全部初始化为1,同时也能处理部分长度为1的情况

4、填表顺序

从左往右,两个表一起填

5、返回值

f_max:f表中的最大值,g_max:g表中的最大值

需要返回两者的最大值

思考过后,去动手实践,趁热打铁,链接:376. 摆动序列 - 力扣(LeetCode)

三、代码示例

class Solution {
public:int wiggleMaxLength(vector<int>& nums) {int n = nums.size();vector<int> f(n,1),g(n,1);for(int i = 0;i<n;i++){for(int j = 0;j<=i-1;j++){if(nums[j]<nums[i]) f[i]=max(g[j]+1,f[i]);if(nums[j]>nums[i]) g[i]=max(f[j]+1,g[i]);}}int f_max=f[0],g_max=g[0];for(auto e : f){if(e>f_max) f_max = e;}for(auto e : g){if(e>g_max) g_max = e;}return max(f_max,g_max);}
};

 

 看到最后,如果对您有所帮助,还请点赞、收藏和关注,点点关注不迷路,我们下期再见!

 

 

相关文章:

  • 使用HTTPS进行传输加密
  • WIN11+eclipse搭建java开发环境
  • Codesys FOR 循环之轴控
  • AIGC学习笔记(8)——AI大模型开发工程师
  • AI读懂天书:Manus AI跨语种手写识别解密
  • 【Python】解析 io.StringIO 与 io.BytesIO
  • Kafka 的 ISR 机制深度解析:保障数据可靠性的核心防线
  • Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作
  • CloudCompare-源码分析-绘制与 3D 场景分离的“前景”元素
  • Remote Sensing投稿记录(投稿邮箱写错、申请大修延期...)风雨波折投稿路
  • 澄清 STM32 NVIC 中断优先级
  • simulink mask的使用技巧
  • SQL进阶之旅 Day 9:高级索引策略
  • C++ 命令模式:设计与实现详解
  • SOC-ESP32S3部分:22-分区表
  • AutoML详解:自动化机器学习的未来
  • GitHub 汉化插件,GitHub 中文化界面安装全教程
  • Git -> Git Stash临时保存当前工程分支修改
  • 计算机组成原理第5章 中央处理器 (CPU)(竟成)
  • LG P4119 [Ynoi2018] 未来日记 Solution
  • 阿里巴巴网站建设分析/新站网站推广公司
  • 自己有服务器怎么建设网站/什么叫软文推广
  • 郑州企业网站建设/厦门seo优化
  • 响应式网站生成/线上电商怎么做
  • 域名哪个网站好/在线网站建设平台
  • 免费网站维护/百度竞价客服