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

代码随想录第五十三天

代码随想录第五十三天

    • Leetcode 1143. 最长公共子序列
    • Leetcode 1035. 不相交的线
    • Leetcode 53. 最大子数组和

Leetcode 1143. 最长公共子序列

题目链接: 最长公共子序列
自己的思路:没想出来!!!

正确思路:首先这道题由于是涉及到了两个数组(或字符串),所以我们要使用二维dp数组来表示;动规五部曲:1、dp数组的含义:dp[i][j]表示以text1[i-1]和text2[j-1]结尾的最长公共子序列的长度(这里为什么是i-1和j-1前面一些题解已经解释了);2、递推公式:dp[i][j]是和三个数组有关系的,分别是dp[i-1][j-1]、dp[i][j-1]和dp[i-1][j],这里就要分情况了,因为我们要判断当前的元素要不要归到最长公共子序列里面去,所以要判断text1[i-1]和text2[j-1]是否相等,如果相等的话,就要在dp[i-1][j-1]基础上加1,如果不相等的话,就要对另外两个求最大值,因为我们的dp[i][j]其实是可以和dp[i][j-1]有关的,我们可以忽略掉text[i-1]这个元素,因为现在text1[i-1]和text2[j-1]并不相等,另一个也是如此!!!3、dp数组的初始化:这里还是和之前那道题一样,全部初始化为0,解释看之前的题;4、遍历顺序:由于dp[i][j]是由前面的数来决定的,所以我们是从前向后遍历;5、打印dp数组:主要用于debug!!!!!

代码:

class Solution {public int longestCommonSubsequence(String text1, String text2) {//转数组,方便操作char[] c1 = text1.toCharArray();char[] c2 = text2.toCharArray();int m = text1.length();int n = text2.length();int[][] dp = new int[m+1][n+1];for (int i = 1;i<=m;i++){for (int j = 1;j<=n;j++){//递推公式if (c1[i-1]==c2[j-1]){dp[i][j] = dp[i-1][j-1] + 1;}else{dp[i][j] = Math.max(dp[i-1][j],dp[i][j-1]);}}}return dp[m][n];}
}

Leetcode 1035. 不相交的线

题目链接: 不相交的线
自己的思路:和上一个题一模一样!!!!!

正确思路:

代码:

class Solution {public int maxUncrossedLines(int[] nums1, int[] nums2) {int m = nums1.length;int n = nums2.length;int[][] dp = new int[m+1][n+1];for (int i=1;i<=m;i++){for (int j = 1;j<=n;j++){//递推公式if (nums1[i-1]==nums2[j-1]){dp[i][j] = dp[i-1][j-1]+1;}else{dp[i][j] = Math.max(dp[i-1][j],dp[i][j-1]);}}}return dp[m][n];}
}

Leetcode 53. 最大子数组和

题目链接: 最大子数组和
自己的思路:贪心!!!!我们只在sum大于0的时候给他继续向后加,因为如果小于等于0的话再向后加是没有意义的,只会削弱后的数!!!!

代码:

class Solution {public int maxSubArray(int[] nums) {int sum = 0;int maxvalue = Integer.MIN_VALUE;for (int i=0;i<nums.length;i++){//如果sum大于0才有意义if (sum<=0){sum = nums[i];}else{sum += nums[i];}//更新最大值maxvalue = Math.max(sum,maxvalue);}return maxvalue;}
}

其他思路:动态规划!!!!!!直接动规五部曲:1、dp数组的含义:以nums[i]结尾的最大子序列的和;2、递推公式:主要分析dp[i]和哪些元素有关系,他可能在dp[i-1]的基础上加上当前元素,也可能直接放弃掉之前的累加和,直接令dp[i]=nums[i],所以要在两者中取较大者;3、dp数组初始化:这里其实只将dp[0]初始化为nums[0]即可,但是因为后面dp[i]的递推公式有一个和nums[i]比较的,我们改成对dp[i]进行比较,所以最开始初始化的时候直接令dp=nums即可!!!!4、遍历顺序:由于后面的状态依赖前面的状态,所以我们采用从前向后遍历的方式;5、打印dp数组:主要用于debug!!!!

代码:

class Solution {public int maxSubArray(int[] nums) {int[] dp = nums;int maxval = nums[0];for (int i =1;i<nums.length;i++){//递推公式dp[i] = Math.max(dp[i-1]+nums[i],dp[i]);maxval = Math.max(maxval,dp[i]);}return maxval;}
}
http://www.lryc.cn/news/141616.html

相关文章:

  • cmd - 如何在不重启的情况下让修改后的hosts生效
  • echarts实现双x轴并且分组滚动效果
  • UE4 地形编辑基础知识 学习笔记
  • AcWing算法提高课-5.5.2最大公约数
  • Kubernetes-CKA考题详解
  • 不同版本.net引用同一个项目
  • 软件开发企业SDL安全培训案例
  • ide-eval-resetter jar包下载、源码、使用介绍
  • 数据压缩算法一览
  • 使用Rust开发命令行工具
  • CentOS中Oracle11g进程有哪些
  • WebRTC之FEC前向纠错协议
  • 软件测试技术分享丨使用Postman搞定各种接口token实战
  • GBU812-ASEMI逆变器专用整流桥GBU812
  • D2007在64位Win7出现 delphi 2007 assertion failure thread32.cpp 的解决办法
  • windows10 docker 安装在D盘
  • Scikit-learn强化学习代码批注及相关练习
  • 执行jmeter端口不够用报错(Address not available)
  • 【Go Web 篇】从零开始:构建最简单的 Go 语言 Web 服务器
  • Android系统-性能-优化概述
  • 用Cmake build OpenCV后,在VS中查看OpenCV源码的方法(环境VS2022+openCV4.8.0) Part II
  • 深度学习5:长短期记忆网络 – Long short-term memory | LSTM
  • LabVIEW开发灭火器机器人
  • 1.2 Kali Linux的网络配置
  • 目标检测的训练过程
  • 软考高级系统架构设计师系列论文七十七:论软件产品线技术
  • 基于大语言模型知识问答应用落地实践 – 知识库构建(上)
  • 一文1500字从0到1搭建 Jenkins 自动化测试平台
  • 前端面试:【实际项目经验】团队协作、代码管理和Git命令梳理
  • 关于异数OS服务器CPU效能分析工具