当前位置: 首页 > news >正文

代码随想录训练营第五十二天|300.最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组

300.最长递增子序列

题目链接/文章讲解/视频讲解:代码随想录

1.代码展示

//300.最长递增子序列
int lengthOfLIS(vector<int>& nums) {if (nums.size() == 1) {return 1;}//step1 构建dp数组//dp[i]的含义是长度未nums数组中长度为i + 1的数组的最长子序列长度vector<int> dp(nums.size(), 1);//step2 状态转移方程//将第i + 1个数和前面的i个数一一对比,找到最大的dp[i]//if (nums[i] > nums[j]) dp[i] = max(dp[i], dp[j] + 1);//step3 初始化//step4 开始遍历int nResult = 0;for (int i = 1; i < nums.size(); i++) {for (int j = 0; j < i; j++) {if (nums[i] > nums[j]) {dp[i] = max(dp[i], dp[j] + 1);}}nResult = max(nResult, dp[i]);}return nResult;
}

 2.本体小节

        思考:明确本题dp数组含义,dp[i]指的是到下标为i的数组中最长递增子序列个数;遍历nums数组,再对下标i前的所有数字进行遍历,通过比较nums[i]和nums[j]的大小,来更新最大dp[i],即dp[i] = max(dp[i], dp[j] + 1);i下次遍历之前,更新result即可,最终取出最大的dp[i]作为结果;注意初始化时每个元素都为1,因为元素本身递增子序列就为1。

        基本思路:如上,注意初始化和状态转移方程。

674. 最长连续递增序列

题目链接/文章讲解/视频讲解:代码随想录

1.代码展示

//674.连续最长递增子序列
int findLengthOfLCIS(vector<int>& nums) {if (nums.size() == 1) {return 1;}vector<int> dp(nums.size(), 1);int nResult = 0;for (int i = 1; i < nums.size(); i++) {if (nums[i] > nums[i - 1]) {dp[i] = dp[i - 1] + 1;}nResult = max(nResult, dp[i]);}return nResult;
}

 2.本题小节

        思考:本题和上一题最大的不同在于,遍历时,当前值只需要和前一个值进行比较即可,不需要对当前值之前的所有值进行遍历;因此dp[i]只与dp[i - 1]有关,如果nums[i] > nums[i - 1],那么dp[i] = dp[i - 1] + 1,并更新result,获得最大的dp[i];初始化时dp均为1。

       基本思路:如上,注意初始化和状态转移方程。

718. 最长重复子数组  

 题目链接/文章讲解/视频讲解:代码随想录

1.代码展示

//718.最长重复子数组
int findLength(vector<int>& nums1, vector<int>& nums2) {vector<vector<int>> dp(nums1.size() + 1, vector<int>(nums2.size() + 1, 0));int nResult = 0;for (int i = 1; i <= nums1.size(); i++) {for (int j = 1; j <= nums2.size(); j++) {if (nums1[i - 1] == nums2[j - 1]) {dp[i][j] = dp[i - 1][j - 1] + 1;nResult = max(nResult, dp[i][j]);}}}return nResult;
}

2.本题小节

        思考:本题和上面两题不同的是本题要比较的是两个数组的最长重复子数组。构建dp数组,dp[i][j]含义是以下标为 i - 1 和 j - 1 为结尾的数组A和B的最长重复子序列,初始化时数组全部初始化为0,这里dp[i][j]的含义就体现了出来,不需要对dp[0][j]和dp[i][0]一个一个初始化。首先对nums1开始遍历,再对nums2遍历,都从1开始,当nums1[i - 1] == nums2[j - 1]时,此时触发状态转移方程,dp[i][j]  = dp[i - 1][j - 1] + 1,并更新result。

        基本思路:注意本题使用的是二维数组,并把每种情况都列举了出来。

http://www.lryc.cn/news/152508.html

相关文章:

  • 前端三大Css处理器之Less
  • Win 教程 Win7实现隔空投送
  • 代码随想录算法训练营Day45 | 70. 爬楼梯 (进阶) | 322. 零钱兑换 | 279. 完全平方数
  • 算法训练营第四十一天(9.2)| 动态规划Part11:最长公共子序列
  • k8s基于rbac权限管理serviceAccount授权管理
  • linux URL访问工具
  • CCF-CSP 29次 第五题【202303-5 施肥】
  • 前端基础4——jQuery
  • 测试人:“躺平?不可能的“, 盘点测试人在职场的优势
  • C++:初识类与this指针
  • 2023应届生java面试紧张失误之一:CAS口误说成开心锁-笑坏面试官
  • Excel_VBA程序文件的加密及解密说明
  • Flutter关于StatefulWidget中State刷新时机的一点实用理解
  • CS420 课程笔记 P2 - 内存编辑和基础的 GameHacking 尝试
  • 【sql】MongoDB 查询 高级用法
  • 监督学习的介绍
  • 【DRONECAN】(三)WSL2 及 ubuntu20.04 CAN 驱动安装
  • Databricks 入门之sql(二)常用函数
  • Simulink建模与仿真(3)-Simulink 简介
  • (超简单)将图片转换为ASCII字符图像
  • In-Context Retrieval-Augmented Language Models
  • 多种免费天气api
  • 深度学习推荐系统(五)DeepCrossing模型及其在Criteo数据集上的应用
  • 图神经网络教程之HAN-异构图模型
  • Jupyter lab 配置
  • 股票行情处理:不复权,前复权,后复权
  • ip地址、LINUX、与虚拟机
  • MySQL存储过程
  • element-ui 自定义loading加载样式
  • 04-Apache Directory Studio下载安装(LDAP连接工具)