力扣题解( 最长递增子序列的个数)

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

给定一个未排序的整数数组 nums返回最长递增子序列的个数

注意 这个数列必须是 严格 递增的。

思路:

用一个maxlen表示当前最长递增数组的长度,maxcount表示最大长度。当进下标为i的元素时,将其和j(0-i-1)之间的元素比较,若大小大于num[j],则由包含j的最大子序列加i仍可能是最大子序列,此时判断当前包含i的最大长度和由j加上i元素的最大长度比较,若大于则更新最大长度和数量(因为此时相当于找了一个更大的来做最长子序列,因此都需要重新计算),若小于则忽略,若等于则数量相加。

再遍历完(0-i-1)后,要更新maxlen和maxcount,若当前的maxlen等于len[i],则表示以i位置结尾的最大长度和(0-i-1)中某个最大长度一致,则maxcount等于count[i]+maxcount,若maxlen小于len[i],则maxlen更新,maxcount更新。若maxlen大于len[i],则表示最长不是包含i的,则不变。

就是一次更新是只看当前i位置的len和count,一次比较是求(0-i)里的最大len和最大count。

复制代码
class Solution {
public:
    int findNumberOfLIS(vector<int>& nums) {
     int n=nums.size();
     vector<int>len(n,1);
  //   len[0]=1;
     vector<int>count(n,1);
     //count[0]=1;
     int retlen=1,retcount=1;
     for(int i=1;i<n;i++)
     {
        for(int j=0;j<i;j++)
        {
            if(nums[i]>nums[j])
            {
               if(len[i]<len[j]+1)
               {
                len[i]=len[j]+1;
                count[i]=count[j];
               }
               else if(len[i]==len[j]+1)
               {
                count[i]+=count[j];
               }
            }
        }
        if(retlen==len[i])
        {
            retcount+=count[i];
        }
        else if(retlen<len[i])
        {
            retcount=count[i];
            retlen=len[i];
        }
     }

     return retcount;
    }
};
相关推荐
灵感__idea37 分钟前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
lwf0061642 小时前
导数学习日记
学习·算法·机器学习
头发够用的程序员3 小时前
从滑动窗口到矩阵运算:img2col算法基本原理
人工智能·算法·yolo·性能优化·矩阵·边缘计算·jetson
武帝为此3 小时前
【数据清洗缺失值处理】
python·算法·数学建模
Halo_tjn4 小时前
Java 基于字符串相关知识点
java·开发语言·算法
念越4 小时前
算法每日一题 Day08|双指针法解决三数之和
算法·力扣
黎阳之光5 小时前
黎阳之光透明管理:视频孪生重构智慧仓储新范式
人工智能·算法·安全·重构·数字孪生
CappuccinoRose6 小时前
回溯法 - 软考备战(四十三)
算法·排列组合·路径·n皇后·子集·解数独·岛屿
AC赳赳老秦6 小时前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw
Robot_Nav6 小时前
Shape-Aware MPPI(SA MPPI)算法:基于RC-ESDF的任意形状机器人实时轨迹优化
算法·机器人·sa-mppi