算法训练(leetcode)二刷第三十七天 | *300. 最长递增子序列、674. 最长连续递增序列、*718. 最长重复子数组

刷题记录

  • *300. 最长递增子序列
  • 674. 最长连续递增序列
    • 基础解法(非动规)
    • 动态规划
  • 718. 最长重复子数组
    • 滚动数组

*300. 最长递增子序列

leetcode题目地址

dp数组含义:
dp[i]表示以nums[i]结尾的最长递增子序列长度,即以nums[i]结尾的子序列的长度。
j从0向i遍历,遇到num[i] > num[j], dp[i] = max(dp[j]+1, dp[i]);

时间复杂度: O ( n 2 ) O(n^2) O(n2)
空间复杂度: O ( n ) O(n) O(n)

// java
class Solution {public int lengthOfLIS(int[] nums) {int len = nums.length; int[] dp = new int[len];int result = 1;// for(int i=0; i<len; i++) dp[i] = 1;Arrays.fill(dp, 1);for(int i=1; i<len; i++){for(int j=0; j<i; j++){if(nums[i] > nums[j]) dp[i] = Math.max(dp[i], dp[j]+1);}if(result < dp[i]) result = dp[i];}return result;}
}

674. 最长连续递增序列

leetcode题目地址

基础解法(非动规)

求最长连续递增子序列,统计子序列记录最长即可。在递增中断时,计数器要置为1而非0,因为下一个子序列从当前元素开始。

时间复杂度: O ( n ) O(n) O(n)
空间复杂度: O ( n ) O(n) O(n)

// java
class Solution {public int findLengthOfLCIS(int[] nums) {int result = 1;int cnt = 1;int len = nums.length;for(int i=1; i<len; i++){if(nums[i]>nums[i-1]) {cnt++;if(cnt > result) result = cnt;}else cnt = 1; // 计数器置为1}return result;}
}

动态规划

dp数组含义:
dp[i]表示以nums[i]结尾的最长连续递增子序列的长度。

初始化:
每个元素本身就是一个连续递增子序列,因此初始化为1,即dp数组均初始化为1。

// java
class Solution {public int findLengthOfLCIS(int[] nums) {int len = nums.length;int[] dp = new int[len];Arrays.fill(dp, 1);int result = 1;for(int i=1; i<len; i++){if(nums[i] > nums[i-1]) dp[i] = dp[i-1]+1;result = Math.max(result, dp[i]);}return result;}
}

718. 最长重复子数组

leetcode题目地址

dp数组含义:
dp[i][j]表示 以nums1[i-1]结尾的子数组A 和以 以nums2[j-1]结尾的子数组B 的最长重复子数组长度。

这里为什么要用i-1和j-1?
因为dp[i][j]的更新依赖于dp[i-1][j-1]的值。也就是说,在nums1[i-1]和nums2[j-1]相等时,更新对应位置长度需要依赖nums1[i-2]和nums2[j-2]的最长重复子数组长度。
以题目示例1举例:nums1 = [1,2,3,2,1], nums2 = [3,2,1,4,7]

  • 当nums1[2] == nums2[0]时,当前位置的最长重复子数组长度依赖于前面的匹配情况,前面相等的串长度为0,因此这里dp[3][1]是1。
  • 当nums1[3] == nums2[1]时,逻辑同上,dp[4][2]的更新依赖于前面的匹配情况,前面有一个元素匹配到,因此这里dp[4][2] = dp[3][1]+1 = 2
  • 当nums1[4] == nums2[2]时,逻辑同上,dp[5][3]的更新依赖于前面的匹配情况,前面有两个元素匹配到,因此这里dp[5][3] = dp[4][2]+1 = 3

到这里就可以总结出状态转移方程,dp[i][j] = dp[i-1][j-1] + 1
由于这里使用了i-1和j-1,在i和j为0时会越界。 因此整体将dp数组下标后移一位,来解决这一问题。(也可单独处理i和j为0的情况,较复杂)

时间复杂度: O ( n 2 ) O(n^2) O(n2)
空间复杂度: O ( n ) O(n) O(n)

// java
class Solution {public int findLength(int[] nums1, int[] nums2) {int len1 = nums1.length;int len2 = nums2.length;int[][] dp = new int[len1+1][len2+1];int result  = 0;if(nums1[0] == nums2[0]) dp[1][1] = 1;for (int i=1; i<=len1; i++){for(int j=1; j<=len2; j++){if(nums1[i-1] == nums2[j-1]){dp[i][j] = dp[i-1][j-1]+1;}result = Math.max(result, dp[i][j]);// System.out.print(dp[i][j] + " ");}// System.out.println();}return result;}
}

滚动数组

注意:
1、思路同上,只是每一层的状态是从上一层拷贝下来的,因此在遍历nums2时要从后向前,防止将前面元素在上一层的状态覆盖
2、当遇到元素不相同是要将对应位置赋值0.

// java
class Solution {public int findLength(int[] nums1, int[] nums2) {int len1 = nums1.length;int len2 = nums2.length;int[] dp = new int[len2+1];int result  = 0;for (int i=1; i<=len1; i++){for(int j=len2; j>=1; j--){if(nums1[i-1] == nums2[j-1]){dp[j] = dp[j-1]+1;} else dp[j] = 0; // 注意这里不相等的时候要有赋0的操作result = Math.max(result, dp[j]);}}return result;}
}

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

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

相关文章

Elasticsearch 相关面试题

1. Elasticsearch基础 Elasticsearch是什么&#xff1f; Elasticsearch是一个分布式搜索引擎&#xff0c;基于Lucene实现。 Mapping是什么&#xff1f;ES中有哪些数据类型&#xff1f; Mapping&#xff1a;定义字段的类型和属性。 数据类型&#xff1a;text、keyword、integer、…

TCP/IP的分层结构、各层的典型协议,以及与ISO七层模型的差别

1. TCP/IP的分层结构 TCP/IP模型是一个四层模型&#xff0c;主要用于网络通信的设计和实现。它的分层结构如下&#xff1a; (1) 应用层&#xff08;Application Layer&#xff09; 功能&#xff1a;提供应用程序之间的通信服务&#xff0c;处理特定的应用细节。 典型协议&am…

pycharm技巧--鼠标滚轮放大或缩小 Pycharm 字体大小

1、鼠标滚轮调整字体 设置 Ctrl 鼠标滚轮调整字体大小 备注&#xff1a; 第一个是活动窗口&#xff0c;即缩放当前窗口 第二个是所有编辑器窗口&#xff0c;即缩放所有窗口的字体 2、插件 汉化包&#xff1a; Chinese Simplified 包

硬件工程师入门教程

1.欧姆定律 测电压并联使用万用表测电流串联使用万用表&#xff0c;红入黑出 2.电阻的阻值识别 直插电阻 贴片电阻 3.电阻的功率 4.电阻的限流作用 限流电阻阻值的计算 单位换算关系 5.电阻的分流功能 6.电阻的分压功能 7.电容 电容简单来说是两块不连通的导体加上中间的绝…

edge浏览器将书签栏顶部显示

追求效果&#xff0c;感觉有点丑&#xff0c;但总归方便多了 操作路径&#xff1a;设置-外观-显示收藏夹栏-始终

【SPIE出版,见刊快速,EI检索稳定,浙江水利水电学院主办】2025年物理学与量子计算国际学术会议(ICPQC 2025)

2025年物理学与量子计算国际学术会议&#xff08;ICPQC 2025&#xff09;将于2025年4月18-20日在中国杭州举行。本次会议旨在汇聚全球的研究人员、学者和业界专家&#xff0c;共同探讨物理学与量子计算领域的最新进展与前沿挑战。随着量子技术的快速发展&#xff0c;其在信息处…

谷歌浏览器更新后导致的刷新数据无法显示

这几天突然出现的问题&#xff0c;就是我做了一个网站&#xff0c;一直用Google展示&#xff0c;前两天突然就是刷新会丢失数据&#xff0c;然后再刷新几次吧又有了&#xff0c;之前一直好好的&#xff0c;后端也做了一些配置添加了CrossOrigin注解&#xff0c;然而换了edge浏览…

UE5从入门到精通之多人游戏编程常用函数

文章目录 前言一、权限与身份判断函数1. 服务器/客户端判断2. 网络角色判断二、网络同步与复制函数1. 变量同步2. RPC调用三、连接与会话管理函数1. 玩家连接控制2. 网络模式判断四、实用工具函数前言 UE5给我们提供了非常强大的多人网路系统,让我们可以很方便的开发多人游戏…

软件需求管理办法,软件开发管理指南(Word原件)

1. 目的 2. 适用范围 3. 参考文件 4. 术语和缩写 5. 需求获取的方式 5.1. 与用户交谈向用户提问题 5.1.1. 访谈重点注意事项 5.1.2. 访谈指南 5.2. 参观用户的工作流程 5.3. 向用户群体发调查问卷 5.4. 已有软件系统调研 5.5. 资料收集 5.6. 原型系统调研 5.6.1. …

利用python和gpt写一个conda环境可视化管理工具

最近在学习python&#xff0c;由于不同的版本之间的差距较大&#xff0c;如果是用环境变量来配置python的话&#xff0c;会需要来回改&#xff0c;于是请教得知可以用conda来管理&#xff0c;但是conda在管理的时候老是要输入命令&#xff0c;感觉也很烦&#xff0c;于是让gpt帮…

【复习】计算机网络

网络模型 OSI 应用层&#xff1a;给应用程序提供统一的接口表示层&#xff1a;把数据转换成兼容另一个系统能识别的格式会话层&#xff1a;负责建立、管理、终止表示层实体之间的通信会话传输层&#xff1a;负责端到端的数据传输网络层&#xff1a;负责数据的路由、转发、分片…

图书馆系统源码详解

本项目是一个基于Scala语言开发的图书馆管理系统。系统主要由以下几个部分组成&#xff1a;数据访问层&#xff08;DAO&#xff09;、数据模型层&#xff08;Models&#xff09;、服务层&#xff08;Service&#xff09;以及用户界面层&#xff08;UI&#xff09;。以下是对项目…

Redis——用户签到BitMap,UV统计

目录 BitMap 使用场景 1. 用户签到系统 2. 用户行为标记 3. 布隆过滤器&#xff08;Bloom Filter&#xff09; BitMap介绍 Redis中的使用 Redis功能示例 添加&#xff1a; 获取&#xff1a; 批量获取&#xff1a; java中实现 统计本月连续签到次数 UV统计 UV 统计…

【数据库】【MySQL】索引

MySQL中索引的概念 索引&#xff08;MySQL中也叫做"键&#xff08;key&#xff09;"&#xff09;是一种数据结构&#xff0c;用于存储引擎快速定找到记录。 简单来说&#xff0c;它类似于书籍的目录&#xff0c;通过索引可以快速找到对应的数据行&#xff0c;而无需…

【SpringBoot AI 集成DeepSeek 大模型API调用】

当DeepSeek开始盛行&#xff0c;提供强大的大语言模型&#xff0c;界面调用不能满足我们的需要&#xff0c;同时提供API接口供我们在服务中调用&#xff0c;来实现各种AI场景。 我们通过将DeepSeek的AI能力与SpringBoot AI相结合&#xff0c;实现智能聊天、问答机器人&#xf…

Linux 性能更好的ftp客户端 lftp 使用详解

简介 LFTP 是一个命令行 FTP 客户端&#xff0c;支持多种文件传输协议&#xff0c;包括 FTP、FTPS、HTTP、HTTPS和SFTP 。它以其通过镜像、后台操作和脚本支持等特性有效管理复杂传输的能力而闻名。 安装 Ubuntu/Debian sudo apt update sudo apt install lftpCentOS/RHEL/…

汽车智能制造企业数字化转型SAP解决方案总结

一、项目实施概述 项目阶段划分&#xff1a; 蓝图设计阶段主数据管理方案各模块蓝图设计方案下一阶段工作计划 关键里程碑&#xff1a; 2022年6月6日&#xff1a;项目启动会2022年12月1日&#xff1a;系统上线 二、总体目标 通过SAP实施&#xff0c;构建研产供销协同、业财一…

【深度学习】矩阵的理解与应用

一、矩阵基础知识 1. 什么是矩阵&#xff1f; 矩阵是一个数学概念&#xff0c;通常表示为一个二维数组&#xff0c;它由行和列组成&#xff0c;用于存储数值数据。矩阵是线性代数的基本工具之一&#xff0c;广泛应用于数学、物理学、工程学、计算机科学、机器学习和数据分析等…

<网络> UDP协议

目录 传输层 再谈端口号 端口号范围划分 认识知名端口号 两个问题 netstat与iostat pidof UDP协议 UDP协议格式 UDP数据封装&#xff1a; UDP数据分用&#xff1a; UDP协议的特点 面向数据报 UDP的缓冲区 UDP使用注意事项 基于UDP的应用层协 传输层 在学习HTTP等应用层协议时&…

大模型面试基础问题

1.1.1 最主流的开源模型&#xff1f; ChatGLM-6B[1] prefix LM LLaMA-7B[2] causal LM 1.1.2 prefix LM和causal LM的区别&#xff1f; 1.1.2.1 Prefix LM Prefix LM&#xff0c;即前缀语言模型&#xff0c;该结构是Google的T5模型论文起的名字&#xff0c;望文知义来说&…