经典DP-最长单调子序列

最长递增子序列

思路

  1. 定义状态
    • 我们定义一个数组 dp,其中 dp[i] 表示以 nums[i] 结尾的最长递增子序列的长度。
  2. 初始化状态
    • 对于数组中的每个元素 nums[i],初始时都可以被视为一个长度为1的递增子序列,因此 dp[i] 的初始值都设为1。
  3. 状态转移方程
    • 对于数组中的每个位置 i,我们遍历它之前的所有位置 jj < i)。
    • 如果 nums[i] 大于 nums[j],说明 nums[i] 可以接在以 nums[j] 结尾的递增子序列后面,形成一个更长的递增子序列。
    • 在这种情况下,我们可以更新 dp[i] 为 dp[j] + 1,表示以 nums[i] 结尾的递增子序列长度是以 nums[j] 结尾的子序列长度加1。
    • 我们需要遍历所有 j < i 的情况,并取 dp[j] + 1 中的最大值来更新 dp[i]
  4. 求解结果
    • 在完成所有状态转移后,dp 数组中的最大值就是最长递增子序列的长度。
    • 因为 dp[i] 存储的是以 nums[i] 结尾的最长递增子序列的长度,所以最长递增子序列的实际长度可能不在数组末尾,而是在数组中的某个位置。
    • 因此,我们需要遍历整个 dp 数组来找到最大值,这个最大值就是最长递增子序列的长度。
  5. 优化空间复杂度
    • 上述方法的空间复杂度是 O(n),因为我们需要一个大小为 n 的 dp 数组来存储状态。
    • 但实际上,我们只需要知道前一个状态 dp[j] 的值来更新当前状态 dp[i],因此可以使用一个变量来替代整个数组,从而将空间复杂度优化到 O(1)。
  6. 实现细节
    • 在实际编码时,我们需要处理边界情况,比如输入数组为空或只有一个元素的情况。
    • 在 main 方法中,我们需要创建 LongestIncreasingSubsequence 类的实例,并调用其 lengthOfLIS 方法来获取结果。

代码


import java.util.Scanner;
//给你一个整数数组nums,
//找到其中最长严格递增子序列的长度
public class 最长递增子序列 {//写一个方法public int lengthOfLIS(int [] nums) {//在方法的开始,我们首先处理边界情况if(nums==null || nums.length==0) {return 0;}//dp[i]将存储以nums[i]结尾的最长递增子序列的长度。int[] dp=new int[nums.length];//初始化一个变量maxLength,用于跟踪目前为止找到的最长递增子序列的长度int maxLength=1;for(int i=0;i<nums.length;i++) {dp[i]=1;//将dp[i]初始化为1,因为任何元素都可以作为一个长度为1的递增子序列。for(int j=0;j<i;j++) {//再用一个内层for循环遍历当前元素之前的所有元素。//在内层循环中,我们检查当前元素nums[i]是否大于前面的元素nums[j]if(nums[i]>nums[j]) {dp[i] = Math.max(dp[i], dp[j]+1);}}maxLength=Math.max(maxLength, dp[i]);}return maxLength;}public static void main(String[] args) {Scanner scan = new Scanner(System.in);最长递增子序列 ss =new 最长递增子序列();int [] nums= {10,9,2,5,3,7,101,18};int result = ss.lengthOfLIS(nums);System.out.println(result);  }
}

最长递增子序列的个数

代码

import java.util.Arrays;public class 最长递增子序列的个数 {public int findNumberOfLIS(int[] nums) {if(nums==null || nums.length==0) {return 0;}int n=nums.length;int[] dp=new int[n];//dp[i] 存储以 nums[i] 结尾的最长递增子序列的长度int[] count = new int[n];//count[i] 存储以 nums[i] 结尾的最长递增子序列的个数Arrays.fill(count, 1);//初始化count数组,每个元素的最长递增子序列至少包含一个元素int maxLength = 1;//最长递增子序列的长度for(int i=0;i<n;i++) {dp[i]=1;for(int j=0;j<i;j++) {if(nums[i]>nums[j]) {if(dp[j]+1>dp[i]) {//如果发现一个更长的递增子序列,更新 dp[i] 并重置 count[i]  dp[i]=dp[j]+1;count[i]=count[j];}else if(dp[j]+1==dp[i]){count[i] += count[j];}}}maxLength = Math.max(maxLength, dp[i]);}int result=0;for(int i=0;i<n;i++) {if(dp[i]==maxLength) {result+=count[i];}}return result;}public static void main(String[] args) {最长递增子序列的个数 solution=new 最长递增子序列的个数();int [] nums= {1,3,5,4,7};int count=solution.findNumberOfLIS(nums);System.out.println(count);}}

知识点

Arrays.fill(count, 1);

 是 Java 中的一个方法调用,用于将数组 count 的所有元素设置为指定的值,即 1。这个方法来自于 java.util.Arrays 类,是一个静态工具类,提供了很多用于操作数组(例如排序、搜索、填充等)的静态方法。

在这个特定的情境下,Arrays.fill(count, 1); 被用来初始化 count 数组。由于我们正在计算最长递增子序列的个数,每个元素至少可以作为一个长度为 1 的递增子序列的结束元素。因此,count 数组的每一个位置都被设置为 1,意味着每个元素开始时都被视为一个独立的递增子序列。

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

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

相关文章

常用的桌面端自动化测试工具

桌面端软件相比Web端软件而言&#xff0c;因为界面元素的多种形态&#xff0c;导致其定位更难&#xff0c;目前市面上常见的定位方式一般是两种&#xff0c;一种是通过控件本身的属性定位&#xff0c;第二种是通过图片识别来定位&#xff0c;市面上常用的可以支持不同操作系统的…

Qt6内嵌CEF

一、下载CEF CEF下载地址&#xff1a;https://cef-builds.spotifycdn.com/index.html 或https://bitbucket.org/chromiumembedded/cef/src/master/ 选择对应系统的版本&#xff08;本教程选择的是116.0.19&#xff09; CMake下载地址&#xff1a;https://cmake.org/download…

thefour--Love is like a tide

最后一部分了&#xff0c;要开始进行我们的训练了。 先上代码&#xff1a; import os import numpy as np from tqdm import tqdm import tensorflow as tf from thetwo import NeuralStyleTransferModel import theone import thethree #创建模型 modelNeuralStyleTransferM…

代码随想录训练营第31天 | 理论基础、LeetCode 455.分发饼干、

目录 理论基础 视频讲解&#xff1a;手把手带你学会操作链表 | 贪心算法理论基础&#xff01;_哔哩哔哩_bilibili LeetCode 455.分发饼干 文章讲解&#xff1a;代码随想录(programmercarl.com) 视频讲解&#xff1a;贪心算法&#xff0c;你想先喂哪个小孩&#xff1f;| Le…

【GameFramework框架内置模块】7、事件(Event)

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址 大家好&#xff0c;我是佛系工程师☆恬静的小魔龙☆&#xff0c;不定时更新Unity开发技巧&#xff0c;觉得有用记得一键三连哦。 一、前言 【GameFramework框架】系列教程目录&#xff1a; https://blog.csdn.net/q7…

【Vue】路由

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;Vue ⛺️稳中求进&#xff0c;晒太阳 目录 路由 单页应用程序 总结&#xff1a; VueRouter 核心步骤&#xff1a; 组件存放目录的问题 路由的封装 声明式导航 声明式导航 - 导航链…

Go语言必知必会100问题-11 使用选项模式

使用选项模式 在设计API时&#xff0c;可能会遇到一个问题&#xff1a;如何处理可选配置&#xff1f;有效的解决可选配置问题可以提高API的灵活性。本文通过一个具体示例说明处理可选配置的一些方法。该示例的要求是设计一个对外提供创建HTTP服务器的库函数。函数定义如下&…

服了,阿里云服务器和腾讯云服务器价格差不多怎么选择?

2024年阿里云服务器和腾讯云服务器价格战已经打响&#xff0c;阿里云服务器优惠61元一年起&#xff0c;腾讯云服务器62元一年&#xff0c;2核2G3M、2核4G、4核8G、8核16G、16核32G、16核64G等配置价格对比&#xff0c;阿腾云atengyun.com整理阿里云和腾讯云服务器详细配置价格表…

高级语言期末2011级B卷(计算机学院)

1.编写函数&#xff0c;实现按照如下公式计算的功能&#xff0c;其中n为自然数 #include <stdio.h>int fac(int n) {if(n0)return 1;elsereturn n*fac(n-1); }float fun(int n) {float flag;float sum0;for(int i0; i<n; i) {flagi/((i1)*fac(i2));sumflag;}return su…

重推请求之curl和fiddler

在实际的项目中会有出现问题&#xff0c;想重现的场景&#xff0c;比较重新调用一个服务&#xff0c;那么如何进行快速的重推请求呢&#xff0c;记录下来&#xff0c;方便备查。 主要有curl和fiddler两种方式&#xff0c;下面详细说。 方式一、curl 命令 curl 是一个利用URL规…

云上攻防-云服务篇弹性计算服务器云数据库实例元数据控制角色AK控制台接管

知识点: 1、云服务-弹性计算服务器-元数据&SSRF&AK 2、云服务-云数据库-外部连接&权限提升 章节点&#xff1a; 云场景攻防&#xff1a;公有云&#xff0c;私有云&#xff0c;混合云&#xff0c;虚拟化集群&#xff0c;云桌面等 云厂商攻防&#xff1a;阿里云&am…

租赁小程序|租赁系统|租赁软件开发带来高效运营

随着社会的不断发展和科技的不断进步&#xff0c;越来越多的企业开始关注设备租赁业务。设备租赁作为一种短期使用设备的方式&#xff0c;为企业提供了灵活和成本节约的优势。针对设备租赁业务的管理和提升企业竞争力的需求&#xff0c;很多企业选择定制开发设备租赁系统。本文…

js 面试 1判断变量是否是数组 2 检测数据类型方法

1 是否是数组 1) typeof 检测数据类型运算符 优点&#xff1a;使用简单 缺点&#xff1a;只能检测基本类型&#xff08;除null外&#xff09; console.log(typeof(10)) //Number console.log(typeof(false)) //boolean console.log(typeof(hello)) //string console.log(typeof…

vue使用gitshot生成gif

vue使用gitshot生成gif 问题背景 本文将介绍vue中使用gitshot生成gif。 问题分析 解决思路&#xff1a; 使用input组件上传一个视频&#xff0c;获取视频文件后用一个video组件进行播放&#xff0c;播放过程进行截图生成图片数组。 demo演示上传一个视频&#xff0c;然后生…

如何使用Docker部署IT-Tools并结合内网穿透实现公网访问本地工具箱服务

作为程序员&#xff0c;在日常工作中&#xff0c;需要借助一些工具来提高我们工作效率&#xff0c;IT-Tools是为开发人员度身打造的一套便捷在线工具。它提供全面功能&#xff0c;使开发者能以更高效方式完成任务。经由IT-Tools&#xff0c;开发人员能轻松应对各类技术挑战&…

C++之数组

1&#xff0c;概述 所谓数组&#xff0c;就是一个集合&#xff0c;里面存放了相同类型的数据元素 特点1&#xff1a;数组中没干过数据元素都是相同的数据类型 特点2&#xff1a;数组都是连续存放位置组成的 2&#xff0c;一维数组 2.1 一维数组的定义 一维数组定义有三种…

Leetcode583. 两个字符串的删除操作 -代码随想录

题目&#xff1a; 代码(首刷自解 2024年2月29日&#xff09;&#xff1a; class Solution { public:// 动态规划 好像和找最长公共子序列一样&#xff1f;int minDistance(string word1, string word2) {int sz1 word1.size();int sz2 word2.size();// dp initvector<vec…

SD-WAN技术:优化国内外服务器访问的关键

在全球化的商业环境中&#xff0c;企业经常需要在国内访问国外的服务器。然而&#xff0c;由于地理位置和网络架构的限制&#xff0c;这种跨国访问往往会遇到速度慢、延迟高等问题。SD-WAN&#xff08;软件定义广域网&#xff09;技术的兴起&#xff0c;为企业提供了一种新的解…

八股文打卡day24——数据库(1)

面试题&#xff1a;左连接和右连接的区别&#xff1f; 我的回答&#xff1a; 左连接的SQL语句是&#xff1a;左表 left join 右表 on 连接条件&#xff0c;表示以左表为基础&#xff0c;将左表的的所有记录与右表进行连接。即使右表中没有与左表匹配的记录&#xff0c;左连接…

Linux-Uboot命令

help命令 进入 uboot 的命令行模式后输入“help”或者“&#xff1f;”&#xff0c;然后按下回车即可查看当前 uboot 所支持的命令。 查看某一个命令的帮助信息&#xff1a;&#xff1f;命令名称 或 help命令名称 信息查询命令 常用的和信息查询有关的命令有 3 个…