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

【代码随想录】刷题Day53

1.最长公共子序列

1143. 最长公共子序列

和之前的一道题目的区别就是这个子序列不需要每个字符相邻。那么条件就变成两种了,一种是当前的字符相同,一种是不同。相同跟之前的条件一样;不同则需要继承上次比较的较大值。if (text1[i - 1] == text2[j - 1]),则dp[i][j] = dp[i - 1][j - 1] + 1;此外就是继承的写法,就是i-1和j-1的字符不一样,那么就是 看i-2和j-1字符组成的大小 以及 i-1和j-2字符组成的大小之间比较的大小取舍,即dp[i][j] = max(dp[i][j - 1], dp[i - 1][j]);

class Solution {
public:int longestCommonSubsequence(string text1, string text2) {vector<vector<int>> dp(text1.size() + 1, vector<int>(text2.size() + 1, 0));for (int i = 1; i < text1.size() + 1; i++){for (int j = 1; j < text2.size() + 1; j++){if (text1[i - 1] == text2[j - 1])dp[i][j] = dp[i - 1][j - 1] + 1;elsedp[i][j] = max(dp[i][j - 1], dp[i - 1][j]);}}return dp[text1.size()][text2.size()];}
};

2.不相交的线

1035. 不相交的线

跟上一题其实是一样的,因为本质都是往后找子列

class Solution {
public:int maxUncrossedLines(vector<int>& nums1, vector<int>& nums2) {vector<vector<int>> dp(nums1.size() + 1, vector<int>(nums2.size() + 1, 0));for (int i = 1; i < nums1.size() + 1; i++){for (int j = 1; j < nums2.size() + 1; j++){if (nums1[i - 1] == nums2[j - 1])dp[i][j] = dp[i - 1][j - 1] + 1;elsedp[i][j] = max(dp[i][j - 1], dp[i - 1][j]);}}return dp[nums1.size()][nums2.size()];}
};

3.最大子数组和

53. 最大子数组和

1.会超出存储范围的dp,其实思路就是暴力解,只是表达式简单易懂。

2.dp[i][j]:从i到j位置的最大子数组和。

3.那么i<j的位置其实都是没有意义的。只考虑二维数组的另外一半。条件其实很简单,就是比较加上j这个节点的数组会不会子数组更大,所以条件为dp[i][j] = dp[i][j - 1] + nums[j];

4.初始化就是:将dp[i][i]位置的数变为nums[i];dp[0][i]为前一个数的累加dp[0][i] = dp[0][i - 1] + nums[i];

class Solution {
public:int maxSubArray(vector<int>& nums) {vector<vector<int>>dp(nums.size(), vector<int>(nums.size(), 0));dp[0][0] = nums[0];for (int i = 1; i < nums.size(); i++){dp[0][i] = dp[0][i - 1] + nums[i];}int ret = nums[0];for (int i = 0; i < nums.size(); i++){dp[i][i] = nums[i];ret = max(ret, dp[i][i]);for (int j = i + 1; j < nums.size(); j++){dp[i][j] = dp[i][j - 1] + nums[j];ret = max(ret, dp[i][j]);}}return ret;}
};

1.dp[i]:为i位置的最大子数组和

2.条件:就是看前面一个dp加上当前节点和单独是该节点的数之间的比较dp[i] = max(dp[i - 1] + nums[i], nums[i]);

3.初始化dp[0] = nums[0];

class Solution {
public:int maxSubArray(vector<int>& nums) {vector<int>dp(nums.size(), 0);dp[0] = nums[0];int ret = dp[0];for (int i = 1; i < nums.size(); i++){dp[i] = max(dp[i - 1] + nums[i], nums[i]);ret = max(ret, dp[i]);}return ret;}
};

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

相关文章:

  • MySQL 索引及查询优化总结
  • 什么是AJAX?
  • 报表生成器FastReport .Net用户指南:显示数据列、HTML标签
  • bootstrap-dialog弹框,去掉遮盖层,可移动
  • 7. user-Agent破解反爬机制
  • 3.Nginx+Tomcat负载均衡和动静分离群集
  • 数据结构与算法之树结构
  • 【python】 用来将对象持久化的 pickle 模块
  • 【博客654】prometheus配置抓取保护以防止压力过载
  • Backtrader官方中文文档:第十三章Observers观察者
  • 算法leetcode|54. 螺旋矩阵(rust重拳出击)
  • 单容水箱建模(自衡单容水箱+无自衡单容水箱)
  • 分享Python7个爬虫小案例(附源码)
  • 我用ChatGPT写2023高考语文作文(一):全国甲卷
  • c++ modbusTCP
  • linux(信号结尾)
  • 【漏洞修复】node-exporter被检测出来pprof调试信息泄露漏洞
  • 在linux 上安装 NFS服务器软件
  • 网卡中的Ring buffer -- 解决 rx_resource_errors 丢包
  • 六月九号补题日记:Codeforces Round 877 (Div. 2)
  • python基础选择题,高中适用
  • Linux 面试题-(腾讯,百度,美团,滴滴)
  • DDD--战略设计步骤
  • Web Scoket简述
  • “Docker 技术在企业中的应用及挑战解决方案“
  • vue中开发包、生产包、全局包的区别以及安装语法
  • list的模拟实现
  • ChatGLM简介和SSE聊天接口测试效果
  • darknet yolo标注、训练详细说明
  • chatgpt赋能python:Python如何产生随机整数?