首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >动态规划子序列问题系列一>最长递增子序列的个数

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

作者头像
用户11305962
发布2025-06-01 13:39:48
发布2025-06-01 13:39:48
1450
举报
文章被收录于专栏:学习学习

题目:


解析:

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

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


代码:

代码语言:javascript
复制
 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;
    }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-12-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档