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

题目:


解析:

这里求最长递增子序列的长度,请看这篇博客: 动态规划子序列问题系列一>最长递增子序列-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;
    }
相关推荐
绵绵细雨中的乡音1 分钟前
动态规划-第六篇
算法·动态规划
程序员黄同学11 分钟前
动态规划,如何应用动态规划解决实际问题?
算法·动态规划
march_birds29 分钟前
FreeRTOS 与 RT-Thread 事件组对比分析
c语言·单片机·算法·系统架构
斯汤雷1 小时前
Matlab绘图案例,设置图片大小,坐标轴比例为黄金比
数据库·人工智能·算法·matlab·信息可视化
云 无 心 以 出 岫2 小时前
贪心算法QwQ
数据结构·c++·算法·贪心算法
俏布斯2 小时前
算法日常记录
java·算法·leetcode
独好紫罗兰2 小时前
洛谷题单3-P5719 【深基4.例3】分类平均-python-流程图重构
开发语言·python·算法
SheepMeMe2 小时前
蓝桥杯2024省赛PythonB组——日期问题
python·算法·蓝桥杯
随便昵称2 小时前
蓝桥杯专项复习——前缀和和差分
c++·算法·前缀和·蓝桥杯
脑子慢且灵2 小时前
蓝桥杯冲刺:一维前缀和
算法·leetcode·职场和发展·蓝桥杯·动态规划·一维前缀和