题目:
解析:
这里求最长递增子序列的长度,请看这篇博客: 动态规划子序列问题系列一>最长递增子序列-CSDN博客
这里主要运用:一个小贪心+状态转移方程的分析方法****完成该题
代码:
javapublic int findNumberOfLIS(int[] nums) { int n = nums.length; int[] len = new int[n]; int[] count = new int[n]; //初始化 for(int i = 0; i < n; i++) len[i] = count[i] = 1; int countMaxVal = 1; int lenMaxVal = 1; for(int i = 1; i < n; i++){ 利用小贪心算法,一边跟新最大长度,一边跟新最大个数 for(int j = 0; j <= i-1; j++){ if(nums[j] < nums[i]){ if(len[j]+1 == len[i]) count[i] += count[j];//计数目前最长递增子序列的个数 else if(len[j]+1 > len[i]){ /** 重新计数 */ len[i] = len[j]+1;//更新最大长度 count[i] = count[j];//更新最大长度的个数 } } } //返回结果也是,利用小贪心算法,一边跟新最大长度,一边跟新最大个数 if(len[i] == lenMaxVal) countMaxVal += count[i]; else if(len[i] > lenMaxVal){ lenMaxVal = len[i]; countMaxVal = count[i]; } } return countMaxVal; }
动态规划子序列问题系列一>最长递增子序列的个数
robin_suli2024-12-14 15:41
相关推荐
hoiii18720 小时前
基于栅格法的机器人工作空间划分系统DragonnAi20 小时前
猫咪如厕检测与分类识别系统系列【十四】 项目结构重新整理-即将开源完整算法机器视觉_Explorer21 小时前
【halcon】编程技巧:鼠标擦除灵智实验室1 天前
PX4状态估计技术EKF2详解(二):EKF2 误差状态动力学与协方差传播米粒11 天前
力扣算法刷题 Day 64 Floyd算法 & A* 算法 & 总结篇XX風1 天前
OpenGL中Face culling 面剔除的具体实现IT猿手1 天前
光伏模型参数估计:基于山羊优化算法(GOA )的光伏模型参数辨识问题求解研究,免费提供完整MATLAB代码链接麻雀飞吧1 天前
期货量化策略讲解:天勤量化下的跨期价差均值回归策略实战sali-tec1 天前
C# 基于OpenCv的视觉工作流-章62-线线距离WolfGang0073211 天前
代码随想录算法训练营 Day53 | 图论 part11
