动态规划子序列问题系列一>最长递增子序列的个数

题目:


解析:

这里求最长递增子序列的长度,请看这篇博客: 动态规划子序列问题系列一>最长递增子序列-CSDN博客

这里主要运用:一个小贪心+状态转移方程的分析方法****完成该题


代码:

java 复制代码
 public 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;
    }
相关推荐
小白程序员成长日记24 分钟前
2025.12.03 力扣每日一题
算法·leetcode·职场和发展
元亓亓亓28 分钟前
LeetCode热题100--20. 有效的括号--简单
linux·算法·leetcode
熊猫_豆豆33 分钟前
LeetCode 49.字母异位组合 C++解法
数据结构·算法·leetcode
ModestCoder_2 小时前
强化学习 Policy 的 Tracking 能力全解析,以Legged_gym为例解说Policy的训练流程
人工智能·算法·自然语言处理·机器人·具身智能
小白程序员成长日记2 小时前
2025.12.02 力扣每日一题
数据结构·算法·leetcode
永远都不秃头的程序员(互关)2 小时前
在vscodeC语言多文件编译实战指南
c语言·数据结构·算法
立志成为大牛的小牛2 小时前
数据结构——五十三、处理冲突的方法——拉链法(王道408)
数据结构·学习·考研·算法
吃着火锅x唱着歌3 小时前
LeetCode 3583.统计特殊三元组
算法·leetcode·职场和发展
FPGA_无线通信3 小时前
OFDM 频偏补偿和相位跟踪(2)
算法·fpga开发
SHOJYS3 小时前
思维难度较大 贪心优化背包 [USACO22DEC] Bribing Friends G
数据结构·算法·深度优先