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

文章目录

  • 前言
  • 一、题目描述
  • 二、解题步骤
    • 1.小demo介绍
    • 2.动态规划
        • 1.状态表示
        • 2.状态转移方程
        • 3.初始化
        • 4.填表顺序
        • 5.返回值
  • 三、代码编写
  • 总结


前言

在本篇文章中,我们将会讲到leetcode中673. 最长递增子序列的个数,我们将会用动态规划方式解决这道问题,同时掌握小demo知识。

一、题目描述

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

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

示例 1:

输入: [1,3,5,4,7]
输出: 2
解释: 有两个最长递增子序列,分别是 [1, 3, 4, 7] 和[1, 3, 5, 7]。
示例 2:

输入: [2,2,2,2,2]
输出: 5
解释: 最长递增子序列的长度是1,并且存在5个子序列的长度为1,因此输出5。

题目描述很简单,这里就不再过多叙述了。
注意一点:严格递增,不可以两个数相等。

二、解题步骤

1.小demo介绍

在解决这道问题之前,我们先来介绍个小demo。
在数组中一次找出最大值出现的次数。

nums={2,2,3,4,6,3,2,4};
我们可以定义两个变量maxval,count
🌟maxval表示数组中最大值,初始化为nums[ 0 ]
 count表示最大值出现的次数,初始化为1(为我们假定第一个数为最大值)
🌟nums[ i ]==maxval,count++;
🌟nums[ i ]<maxval,无视;
🌟nums[ i ]>maxval,说明当前并不是最大值,需要更新最大值和计数,maxval=nums[ i ],count=1;

2.动态规划

1.状态表示

经验+题目要求

dp[ i ]:以i位置为结尾的所有子序列中,最长递增子序列的个数

我们先来试一下是否能够推出状态转移方程。
我都不知道以 i 为结尾的最⻓递增⼦序列的「⻓度」是多少,那怎末知道个数呢??

所以一个状态表示解决不了问题,我们必须知道多长,才能知道个数。

len[ i ]:以i位置为结尾的所有子序列中,最长递增子序列的长度
count[ i ]:以i位置为结尾的所有子序列中,最长递增子序列的个数

2.状态转移方程

我们可以两个表一起进行填写
🌟第一种情况,自己构成一个子序列,此时len[ i ]=1,count[ i ]=1;
🌟其他情况,与前面的结合形成子序列,计算len[ i ],我们在300. 最长递增子序列博客中已经讲述过了,这里不再过多阐述。
🌟我们主要看一下count[ i ]的计算。
我们要计算count[ i ],我们需要根据len[ i ],找到最长长度。
  💗💗len[ j ]+1>len[ i ].说明我们第一次找到最大长度,len[ i ]=len[ j ]+1,count[ i ]=count[ j ];
  💗💗len[ j ]+1<len[ i ],说明此时的长度还不如上次找到的长度长,可以无视
  💗💗len[ j ]+1==len[ i ],说明此时又一次找到了最大长度,count[ i ]+=count[ j ].

上面的叙述和小demo十分相似。

下面根据动图进一步理解一下

在这里插入图片描述
在这里插入图片描述

3.初始化

两个表都都初始化为1。

4.填表顺序

从左到右

5.返回值

我们用maxlen表示最长递增子序列的长度。
我们应该返回所有长度等于maxlen的子序列的个数。

这和小demo十分相似。
我们可以边填表,边进行查找。

三、代码编写

class Solution {
public:int findNumberOfLIS(vector<int>& nums) {int n=nums.size();//创建dp表+初始化vector<int>len(n,1);vector<int>count(n,1);//记录最终结果int maxlen=1;int maxcount=1;//填表for(int i=1;i<n;i++){for(int j=0;j<i;j++){if(nums[j]<nums[i]){//重新计数if(len[j]+1>len[i]){len[i]=len[j]+1;count[i]=count[j];}else if(len[j]+1==len[i]){count[i]+=count[j];}}}if(maxlen==len[i]){maxcount+=count[i];}//重新计数else if(maxlen<len[i]){maxlen=len[i];maxcount=count[i];}}//返回结果return maxcount;}
};

总结

以上就是我们对Leetcode中最长递增子序列的个数详细介绍,希望对大家的学习有所帮助,仅供参考 如有错误请大佬指点我会尽快去改正 欢迎大家来评论~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/691100.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Star-CCM+绘制网格-全局网格定义(网格类型选择、薄体网格、网格重置)

前言 绘制网格是有限体积法仿真中必不可少的环节。目前Star-CCM+新版本(2304版)导入面网格只可以导入到部件中。网格类型也只能在操作中完成。零部件导入部件后,选中参与计算的全部部件→右键选择“将部件分配给区域”。此处需要注意的是,只有分配给区域后的部件才能进行网…

HNCTF-PWN

1.ez_pwn 直接看危险函数&#xff0c;不能溢出&#xff0c;只能覆盖ebp。 后面紧接的又是leave,ret 很明显是栈迁移&#xff0c;通过printf打印出ebp&#xff0c;通过偏移计算出栈地址。 通过gdb调试&#xff0c;偏移是0x38 以下是payload&#xff1a; from pwn import * #i…

HR人才测评,表达能力与岗位胜任力素质测评

什么是表达能力&#xff1f; 表达能力指的就是在语言能力基础之上发展形成的一种语用能力&#xff0c;可以结合自己所掌握的语言来实现交际的目的&#xff0c;能正确且灵活的把语言材料组合成为语言并且表达出想要表达的内容。 在百度百科中有如此定义&#xff0c;表达能力…

每日两题 / 101. 对称二叉树 230. 二叉搜索树中第K小的元素(LeetCode热题100)

101. 对称二叉树 - 力扣&#xff08;LeetCode&#xff09; 用两个指针同时遍历树的左右子树即可 每次遍历时&#xff0c;一个指针向左&#xff0c;另一个就要向右。一个向右&#xff0c;另一个就要向左 /*** Definition for a binary tree node.* struct TreeNode {* in…

其他的 框架安全:Apache Shiro 漏洞序列.(CVE-2016-2807)

什么是 Apache Shiro Apache Shiro 是一个强大且易用的Java安全框架&#xff0c;它为应用程序提供了身份验证、授权、加密和会话管理等常见的安全功能。漏洞大多会发生在登录处&#xff0c;返回包里包含remeberMedeleteMe字段.&#xff08; Shiro 这个属于第三方的&#xff0c…

LLM一些适合小白的入门项目和视频

AIX 大模型专区学习&#xff08;史上最丰富&#x1f973;&#xff09; https://github.com/stay-leave/enhance_llm 图谱大哥五一写得。 【对于卷积神经网络&#xff0c;硕士博士不需要搞明白原理&#xff0c;只要会应用是这样吗&#xff1f;-pytorch/深度学习/神经网络】 htt…

【系统架构师】-案例篇(一)UML用例图

1、概述 用于表示系统功能需求&#xff0c;以及应用程序与用户或者与其他应用程序之间的交互关系。 2、组成 参与者&#xff08;Actors&#xff09;&#xff1a;与系统交互的用户或其他系统。用一个人形图标表示。用例&#xff08;Use Cases&#xff09;&#xff1a;系统需要…

【LeetCode:2391. 收集垃圾的最少总时间 + 二分】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

浅析vue3自定义指令

vue3中可以像下面这样使用自定义指令。 这里我们只是定义了一个vFoucs变量&#xff0c;vue怎么知道这是一个指令呢&#xff1f; 这是因为约定大于配置&#xff0c;vue3中有这样一个约定&#xff08;截图来自官方文档&#xff09;&#xff1a; 注意这里说的是驼峰命令&#x…

远程点击没反应

目录 todesk远程登录后点击没反应 解决方法&#xff1a; 方法1 快捷键&#xff1a; 方法2 界面点击Ctrl Alt Delete todesk&#xff0c;向日葵远程登录后点击没反应 todesk远程登录后点击没反应 解决方法&#xff1a; 方法1 快捷键&#xff1a; Ctrl Alt Delete 方法…

Map按value降序并统计

package com.ldj.cloud.user.demo;import java.util.*;/*** User: ldj* Date: 2024/5/11* Time: 10:03* Description: map按value降序*/ public class Tr {public static void main(String[] args) {ArrayList<String> list new ArrayList<>();list.add("a&q…

Linux 第二十八章

&#x1f436;博主主页&#xff1a;ᰔᩚ. 一怀明月ꦿ ❤️‍&#x1f525;专栏系列&#xff1a;线性代数&#xff0c;C初学者入门训练&#xff0c;题解C&#xff0c;C的使用文章&#xff0c;「初学」C&#xff0c;linux &#x1f525;座右铭&#xff1a;“不要等到什么都没有了…