leetcode 673.最长递增子序列的个数

上一题只需要知道最长递增子序列的长度就行了,那样的话直接一个dp就完事了,但是呢,这里说了需要记录这个最长长度递增子序列的个数,这下的话,如果你想用原先的思路,其实可以,但是要能做到计数的话,需要你再定义一个数组cnt用来记录以nums[i]为尾的最长子序列个数。

思路:首先我们根据最长递增子序列的思路,知道dp是用来记录以nums[i]为尾的最长子序列长度的,那么我们要在动态规划实现递推的同时实现cnt计数。

我们开for循环直接从0开始就行了,因为不需要顾及特殊情况n=0或n=1,由于我们是需要实现nums的数组遍历的,所以从0开始就好。然后就直接照着上一题的思路直接抄上,直到我们判断nums[i]与nums[j]的大小时,开始不一样:

当我们判断nums[i]>nums[j]时,说明我们是可以把当前nums[i]接到以nums[j]为尾的子序列上的,由于我们需要计数的操作,所以不会使用max函数。这时就是判断dp[i]与dp[j]+1的大小,如果后者大,那么就更新dp[i],它的个数cnt[i]也随之更新到cnt[j](cnt[i]在初始时是1,我们直接初始化就行);我们还需要判断dp[i]==dp[j]+1的可能性。为什么呢?当我们加上这nums[i]这一个数的时候这个以nums[j]结尾的子序列才刚刚和dp[i]的个数相等,那也就是相当于子序列长度为dp[i]的子序列又多了cnt[j]个,可以想一下,细品一下。这个时候,cnt[i]+=cnt[j],这时才是dp[i]所代表的个数。

然后在我们判断完dp[i]之后,我们需要做一个比较,也就是对于目前最长长度的比较。如果说这个时候dp[i]比目前最长长度还要大,那么dp[i]就是新的最长长度,那么记录的最长长度递增子序列的个数也就是dp[i]所对应的cnt[i]的个数了,就不用之前的那个个数了,直接覆盖掉。

如果说我们这个时候dp[i]==目前的最长长度,也就是说目前最长长度的子序列个数又多了dp[i]个,和上面的思路一样,直接把当前记录的子序列个数+cnt[i]。这样一直更新代换下去。

上代码:

复制代码
class Solution {
public:
    int findNumberOfLIS(vector<int>& nums) {
        int n=nums.size();
        int res=INT_MIN;
        vector<int>dp(n);
        vector<int>cnt(n);
        int len=0;
        int count=0;
        for(int i=0;i<n;i++){
            dp[i]=1;
            cnt[i]=1;
            for(int j=0;j<i;j++){
                if(nums[i]>nums[j]){
                    if(dp[j]+1>dp[i]){
                        dp[i]=dp[j]+1;
                        cnt[i]=cnt[j];
                    }
                    else if(dp[j]+1==dp[i])
                    cnt[i]+=cnt[j];
                }
            }
            if(dp[i]>len){
                len=dp[i];
                count=cnt[i];
            }
            else if(dp[i]==len)
            count+=cnt[i];
        }
        return count;
    }
};
相关推荐
爱学习的小鱼gogo7 分钟前
pyhton 螺旋矩阵(指针-矩阵-中等)含源码(二十六)
python·算法·矩阵·指针·经验·二维数组·逆序
坚持编程的菜鸟42 分钟前
LeetCode每日一题——二进制求和
c语言·算法·leetcode
Glink1 小时前
现在开始将Github作为数据库
前端·算法·github
WWZZ20251 小时前
快速上手大模型:机器学习6(过拟合、正则化)
人工智能·算法·机器学习·计算机视觉·机器人·slam·具身感知
ceclar1232 小时前
C++Lambda表达式
开发语言·c++·算法
2401_841495642 小时前
【强化学习】动态规划算法
人工智能·python·算法·动态规划·强化学习·策略迭代·价值迭代
WWZZ20252 小时前
快速上手大模型:机器学习5(逻辑回归及其代价函数)
人工智能·算法·机器学习·计算机视觉·机器人·slam·具身感知
DuHz2 小时前
基于频率分集阵列的MIMO雷达联合距离角度估计——论文阅读
论文阅读·算法·汽车·信息与通信·毫米波雷达
INGNIGHT2 小时前
单词搜索 II · Word Search II
数据结构·c++·算法
黄卷青灯773 小时前
标定系数为什么会存储在相机模组里面,在标定的时候,算法是在割草机的X3板上运行的啊?
数码相机·算法·相机内参