题目:
解析:
这里求最长递增子序列的长度,请看这篇博客: 动态规划子序列问题系列一>最长递增子序列-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
相关推荐
CS创新实验室7 分钟前
《计算机网络》深入学:海明距离与海明码WW_千谷山4_sch9 分钟前
MYOJ_10599:CSP初赛题单10:计算机网络大厂技术总监下海14 分钟前
用户行为分析怎么做?ClickHouse + 嵌套数据结构,轻松处理复杂事件YuTaoShao30 分钟前
【LeetCode 每日一题】1458. 两个子序列的最大点积——(解法三)状态压缩位东风37 分钟前
希尔排序(Shell Sort)详解AI科技星1 小时前
光速飞行器动力学方程的第一性原理推导、验证与范式革命橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——leetCode 946 题:验证栈序列闻缺陷则喜何志丹1 小时前
【状态机动态规划】3686. 稳定子序列的数量|1969寻星探路1 小时前
【算法通关】双指针技巧深度解析:从基础到巅峰(Java 最优解)
