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

Day46 算法记录| 动态规划 13(子序列)

这里写目录标题

  • 300.最长递增子序列
  • 674. 最长连续递增序列
  • 718. 最长重复子数组

300.最长递增子序列

视频解析:

第一层for循环遍历每一个元素,
------- 第二层for循环找到当前元素前面有几个小于该值的元素
结尾需要统计最多的个数

class Solution {public int lengthOfLIS(int[] nums) {int n = nums.length;int[] dp = new int[n];//1.初始化Arrays.fill(dp,1);int res =1;for(int i=1;i<n;i++){//第二层for(int j=0;j<i;j++){if(nums[j]<nums[i]){dp[i] = Math.max(dp[i],dp[j]+1);}}res = Math.max(res,dp[i]);}return res;}
}

674. 最长连续递增序列

方法一:动态规划:dp[i]表示前面有几个连续小于当前位置的值

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

方法二:贪心

class Solution {public int findLengthOfLCIS(int[] nums) {int n = nums.length;int count =1;int res =1;for(int i=0;i<n-1;i++){if(nums[i]<nums[i+1]){count++;}else{count=1;}res = Math.max(res,count);}return res;}
}

718. 最长重复子数组

讲解的很好

class Solution {public int findLength(int[] A, int[] B) {int res =0;int[][] dp = new int[A.length+1][B.length+1];for(int i=1;i<=A.length;i++){for(int j =1;j<=B.length;j++){if(A[i-1] == B[j-1]){dp[i][j] = dp[i-1][j-1]+1;}res =Math.max(dp[i][j],res);}}return res;}
}

方法二:一维数组
因为当前元素依赖于(x-1,y-1),所以就需要从后向前去遍历
相当于在二维空间里面,从最后一行开始遍历

class Solution {public int findLength(int[] A, int[] B) {int res =0;int[] dp = new int[B.length+1];for(int i=1;i<=A.length;i++){ // 就像是商品for(int j =B.length;j>0;j--){if(A[i-1]==B[j-1]){dp[j] = dp[j-1]+1;}else{dp[j] =0;}res = Math.max(res,dp[j]);}}return res;}
}
http://www.lryc.cn/news/99680.html

相关文章:

  • 结构型-桥接模式(Bridge Pattern)
  • 基于小波哈尔法(WHM)的一维非线性IVP测试问题的求解(Matlab代码实现)
  • 前端(Electron Nodejs)如何读取本地配置文件
  • 没有 telnet 不能测试端口?容器化部署最佳的端口测试方式
  • 漏洞发现-BurpSuite插件-Fiora+Fastjson+Shiro
  • Elasticsearch-倒排索引
  • pagehelper与mybatis-plus冲突的解决办法
  • 解决使用Timer时出现Task already scheduled or cancelled异常的问题
  • P1175 后缀表达式
  • 【HashMap】49. 字母异位词分组
  • golang实现多态
  • formatter的用法,深拷贝, Object.assign 方法实战。
  • Windows上安装和使用git到gitoschina和github上_亲测
  • MATLAB算法实战应用案例精讲-【深度学习】预训练模型GPTXLNet
  • Spring data JPA常用命令
  • Excel的使用
  • 大数据课程D4——hadoop的MapReduce
  • java策略模式
  • Vue2封装自定义全局Loading组件
  • docker 搭建jenkins
  • 【Docker】Docker 部署 Mysql 并设置数据持久化
  • 【ARM 常见汇编指令学习 5 -- arm64汇编指令 wzr 和 xzr】
  • 4.4 成员变量与局部变量的区别有哪些?
  • 学生管理系统-03项目案例(3)
  • Banana Pi BPI-KVM – 基于 Rockchip RK3568 SoC 的 KVM over IP 解决方案
  • 面试:Spring Cloud和Kubernetes的优缺点
  • TSINGSEE青犀视频安防监控视频平台EasyCVR新增密码复杂度提示
  • 前端开发中的正则表达式:解密规则的魔法
  • const的用法
  • 机器学习深度学习——模型选择、欠拟合和过拟合