题目:
解析:
这里求最长递增子序列的长度,请看这篇博客: 动态规划子序列问题系列一>最长递增子序列-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
相关推荐
不会敲代码的灵长类7 分钟前
机器学习算法-逻辑回归拓端研究室TRL16 分钟前
消费者网络购物意向分析:调优逻辑回归LR与决策树模型在电商用户购买预测中的应用及特征重要性优化南玖yy19 分钟前
C++ 类模板三参数深度解析:从链表迭代器看类型推导与实例化(为什么迭代器类模版使用三参数?实例化又会是怎样?)进阶的小蜉蝣21 分钟前
[leetcode] 二分算法JK0x0724 分钟前
代码随想录算法训练营 Day61 图论ⅩⅠ Floyd A※ 最短路径算法Mi Manchi2626 分钟前
力扣热题100之对称二叉树緈福的街口27 分钟前
【leetcode】459.重复的子字符串CoovallyAIHub1 小时前
基于YOLO-NAS-Pose的无人机象群姿态估计:群体行为分析的突破二猛子1 小时前
排序算法-归并排序与快速排序依然易冷1 小时前
【复杂指令遵循 Benchmark】论文分享:CodeIF