题目:
解析:
这里求最长递增子序列的长度,请看这篇博客: 动态规划子序列问题系列一>最长递增子序列-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 分钟前
27. 移除元素TracyCoder12317 分钟前
LeetCode Hot100(28/100)——104. 二叉树的最大深度执着25927 分钟前
力扣hot100 - 101、对称二叉树多恩Stone30 分钟前
【3D-AICG 系列-1】Trellis v1 和 Trellis v2 的区别和改进数智工坊32 分钟前
【数据结构-栈、队列、数组】3.3栈在括号匹配-表达式求值上mit6.82436 分钟前
模运算|z函数 字符串匹配阿豪只会阿巴37 分钟前
【吃饭香系列】二周目|代码随想录算法训练营第七天|454.四数相加II |383. 赎金信 |15. 三数之和 |18. 四数之和小O的算法实验室40 分钟前
2025年COR SCI2区,考虑风场影响的无人机搜救覆盖路径规划精确界算法,深度解析+性能实测xqqxqxxq42 分钟前
洛谷算法1-3 暴力枚举(NOIP经典真题解析)java(持续更新)_OP_CHEN43 分钟前
【算法基础篇】(五十五)卡特兰数封神之路:从括号匹配到二叉树构造,组合数学的万能钥匙!
