代码随想录训练营day52
题目一:最长上升子序列
力扣题目链接
题目描述:
给你一个整数数组 nums
,找到其中最长严格递增子序列的长度。
子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7]
是数组 [0,3,1,6,2,2,7]
的子序列。
思路分析:代码随想录
动归五部曲:
- dp[i]的定义:dp[i]表示i之前包括i的以nums[i]结尾最长上升子序列的长度
- 状态转移方程:位置i的最长升序子序列等于j从0到i-1各个位置的最长升序子序列 + 1 的最大值。所以:if (nums[i] > nums[j]) dp[i] = max(dp[i], dp[j] + 1);
- dp[i]的初始化:每一个i,对应的dp[i](即最长上升子序列)起始大小至少都是1.
- 确定遍历顺序:dp[i] 是有0到i-1各个位置的最长升序子序列 推导而来,那么遍历i一定是从前向后遍历。
- 举例推导dp数组
解法:
class Solution {public int lengthOfLIS(int[] nums) {int[] dp = new int[nums.length];Arrays.fill(dp, 1);for (int i = 0; i < dp.length; i++) {for (int j = 0; j < i; j++) {if (nums[i] > nums[j]) {dp[i] = Math.max(dp[i], dp[j] + 1);}}}int res = 0;for (int i = 0; i < dp.length; i++) {res = Math.max(res, dp[i]);}return res;}
}
题目二:最长连续递增序列
力扣题目链接
题目描述:
给定一个未经排序的整数数组,找到最长且 连续递增的子序列,并返回该序列的长度。
连续递增的子序列 可以由两个下标 l
和 r
(l < r
)确定,如果对于每个 l <= i < r
,都有 nums[i] < nums[i + 1]
,那么子序列 [nums[l], nums[l + 1], ..., nums[r - 1], nums[r]]
就是连续递增子序列。
思路分析:代码随想录
- 确定dp数组(dp table)以及下标的含义:dp[i]:以下标i为结尾的数组的连续递增的子序列长度为dp[i]
- 确定递推公式:如果 nums[i + 1] > nums[i],那么以 i+1 为结尾的数组的连续递增的子序列长度 一定等于 以i为结尾的数组的连续递增的子序列长度 + 1 。即:dp[i + 1] = dp[i] + 1;
- dp数组如何初始化:dp[i]应该初始1
- 确定遍历顺序:从递推公式上可以看出,dp[i + 1]依赖dp[i],所以一定是从前向后遍历。
- 举例推导dp数组
解法:
class Solution {public static int findLengthOfLCIS(int[] nums) {int[] dp = new int[nums.length];for (int i = 0; i < dp.length; i++) {dp[i] = 1;}int res = 1;for (int i = 0; i < nums.length - 1; i++) {if (nums[i + 1] > nums[i]) {dp[i + 1] = dp[i] + 1;}res = res > dp[i + 1] ? res : dp[i + 1];}return res;}
}
题目三:最长重复子数组
力扣题目链接
题目描述:给两个整数数组 nums1
和 nums2
,返回 两个数组中 公共的 、长度最长的子数组的长度
思路分析:代码随想录
解法:
class Solution {public int findLength(int[] nums1, int[] nums2) {int result = 0;int[][] dp = new int[nums1.length + 1][nums2.length + 1];for (int i = 1; i < nums1.length + 1; i++) {for (int j = 1; j < nums2.length + 1; j++) {if (nums1[i - 1] == nums2[j - 1]) {dp[i][j] = dp[i - 1][j - 1] + 1;result = Math.max(result, dp[i][j]);}}}return result;}
}
代码随想录训练营day52相关推荐
- 代码随想录训练营day52, 最长递增子序列, 最长连续递增序列, 最长重复子数组
最长递增子序列 dp[i]的定义, 表示i之前包括i的以nums[i]结尾最长上升子序列的长度 递推: if(nums[i] > nums[j]) dp[i] = max(dp[i], dp[j ...
- 【代码随想录训练营】Day43-动态规划
代码随想录训练营 Day43 今日任务 1049.最后一块石头的重量Ⅱ 494.目标和 474.一和零 语言:Java 1049. 最后一块石头的重量Ⅱ 链接:https://leetcode.cn/ ...
- 代码随想录训练营day8
目录 题目一:反转字符串 解法一:数值交换 解法二:位运算 题目二:反转字符串|| 题目三:替换空格 解法一:双指针 解法二:使用额外空间 题目四:翻转字符串里的单词 解法一: 解法二:纯属娱乐 题目 ...
- 【代码随想录训练营】【Day14】第六章|二叉树|理论基础|递归遍历|迭代遍历|统一迭代
理论基础 二叉树的定义形式有:节点指针和数组 在数组中,父节点的下标为i,那么其左孩子的下标即i*2+1,右孩子的下标即为i*2+2 二叉树的常见遍历形式有:前序遍历.后序遍历.中序遍历和层序遍历 前 ...
- 代码随想录训练营day56
题目一:两个字符串的删除操作 力扣题目链接 题目描述: 给定两个单词 word1 和 word2 ,返回使得 word1 和 word2 相同所需的最小步数. 每步 可以删除任意一个字符串中的一个字 ...
- 代码随想录训练营day57
题目一:回文子串 力扣题目链接 题目描述: 给你一个字符串 s ,请你统计并返回这个字符串中 回文子串 的数目. 回文字符串 是正着读和倒过来读一样的字符串. 子字符串 是字符串中的由连续字符组成的一 ...
- 代码随想录训练营day53
题目一:最长公共子序列 力扣题目链接 题目描述: 给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度.如果不存在 公共子序列 ,返回 0 . 一个字符串的 子序列 ...
- 代码随想录训练营day55
题目一:判断子序列 力扣题目链接 题目描述: 给定字符串 s 和 t ,判断 s 是否为 t 的子序列. 字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符 ...
- 代码随想录训练营day48
题目一:打家劫舍 力扣题目链接 题目描述: 你是一个专业的小偷,计划偷窃沿街的房屋.每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上 ...
最新文章
- 【c语言】蓝桥杯算法提高 Quadratic Equation
- Windows应用程序文件格式转换控件LEADTOOLS ePrint Professional
- python多线程下载百度网盘_python多线程突破百度云限速下载
- vue使用Google Map
- Java实现的一个简单的模板渲染
- Class类和Object类及用法(二)
- Eclipse 安装离线版 Jrebel
- 基于FPGA的循迹小车,控制器:Xilinx-Ego1
- 网络模型(ISO,TCP/IP)
- 网络管理员和网络工程师的区别
- 用mysql触发器做数据统计
- 操作系统------虚拟存储器 请求分页存储管理方式
- 矢量切片地图前端开发tileserver-gl
- 你到底能用Python做什么?下面是Python的三个主要应用程序。
- 拉格朗日插值法python实现
- mini2440 linux内核编译与移植 课程设计,linux内核移植步骤-mini2440
- spark-standalone
- 自制CA证书,自制客户端,服务端证书
- 51. 常用的数学工具类8-七星彩号码生成器
- java画脸_二次元人物侧脸怎么画?对于初学者来说怎么画?
热门文章
- 信息系统项目管理师教程(第3版)- 马斯洛需求层次理论
- 电信3g手机僵局中国it
- PTA 7-10 公路村村通 (30分)
- 一键摸鱼神器火了!专为 Windows 系统打造,老板在身后也可以很淡定
- 我的世界重置服务器文件指令,我的世界spigot后台文件指令解读
- Python趣味编程(一)破解刘谦的“读心术”(原创)
- 海蜘蛛路由免费版也可以看流量
- python pandas 豆瓣电影 top250 数据分析
- 物联网操作系统Zephyr(入门篇)之1.1 Zephyr源码架构
- DDR Layout Guide-DDR布线规则与过程