代码随想录算法训练营第36期DAY57

news2025/1/11 19:53:59

DAY57

今天的好消息:能去华五。

1143最长公共子序列

Code:

  1. class Solution {
  2. public:
  3.     int longestCommonSubsequence(string text1, string text2) {
  4.         vector<vector<int>> dp(text1.size()+1,vector<int>(text2.size()+1,0));
  5.         for(int i=1;i<=text1.size();i++){
  6.             for(int j=1;j<=text2.size();j++){
  7.                 if(text1[i-1]==text2[j-1]) dp[i][j]=dp[i-1][j-1]+1;
  8.                 else dp[i][j]=max(dp[i-1][j],dp[i][j-1]);
  9.             }
  10.         }
  11.         return dp[text1.size()][text2.size()];
  12.     }
  13. };

1035不相交的线

分析法和上一题的图片一样。

  1. class Solution {
  2. public:
  3.     int maxUncrossedLines(vector<int>& nums1, vector<int>& nums2) {
  4.         vector<vector<int>>dp(nums1.size()+1,vector<int>(nums2.size()+1,0));
  5.         for(int i=1;i<=nums1.size();i++){
  6.             for(int j=1;j<=nums2.size();j++){
  7.                 if(nums1[i-1]==nums2[j-1]) dp[i][j]=dp[i-1][j-1]+1;
  8.                 else dp[i][j]=max(dp[i-1][j],dp[i][j-1]);
  9.             }
  10.         }
  11.         return dp[nums1.size()][nums2.size()];
  12.     }
  13. };

53最大子序和

竟然做过这一题,

Try again:

想起来了,是贪心算法,sum<0会减小后一位数字,因此continue;同时记录过程中的maxres.

没白学,做出来了,能感觉自己进步了很多:

  1. class Solution {
  2. public:
  3.     int maxSubArray(vector<int>& nums) {
  4.         int res=INT_MIN;
  5.         int sum=0;
  6.         for(int i=0;i<nums.size();i++){
  7.             sum+=nums[i];
  8.             res=max(sum,res);
  9.             if(sum<0){
  10.                 sum=0;
  11.                 continue;
  12.             }
  13.         }
  14.         return res;
  15.     }
  16. };

动态规划:

动态规划也想出来了,很厉害:

  1. class Solution {
  2. public:
  3.     int maxSubArray(vector<int>& nums) {
  4.         int res=0;
  5.         vector<intdp(nums.size()+1,0);
  6.         for(int i=1;i<=nums.size();i++){
  7.             dp[i]=max(0,dp[i-1]+nums[i-1]);
  8.             res=max(res,dp[i]);
  9.         }
  10.         sort(nums.begin(),nums.end());
  11.         if(nums[nums.size()-1]<0return nums[nums.size()-1];
  12.         return res;
  13.     }
  14. };

不用快排可以吗,当然:

  1. class Solution {
  2. public:
  3.     int maxSubArray(vector<int>& nums) {
  4.         int res=0,mymax=INT_MIN;
  5.         vector<intdp(nums.size()+1,0);
  6.         for(int i=1;i<=nums.size();i++){
  7.             mymax=max(mymax,nums[i-1]);
  8.             dp[i]=max(0,dp[i-1]+nums[i-1]);
  9.             res=max(res,dp[i]);
  10.         }
  11.         if(mymax<0return mymax;
  12.         return res;
  13.     }
  14. };

看看答案:

题解写得好:实现一下:

记得记录过程中的最大值,并且注意res的初值。

  1. class Solution {
  2. public:
  3.     int maxSubArray(vector<int>& nums) {
  4.         vector<intdp(nums.size());
  5.         int res=nums[0];
  6.         dp[0]=nums[0];
  7.         for(int i=1;i<nums.size();i++) dp[i]=max(dp[i-1]+nums[i],nums[i]),res=max(res,dp[i]);
  8.         return res;
  9.     }
  10. };

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1811326.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LeetCode-day09-419. 甲板上的战舰

LeetCode-day09-419. 甲板上的战舰 题目描述示例示例1&#xff1a;示例2&#xff1a; 思路代码 题目描述 给你一个大小为 m x n 的矩阵 board 表示甲板&#xff0c;其中&#xff0c;每个单元格可以是一艘战舰 ‘X’ 或者是一个空位 ‘.’ &#xff0c;返回在甲板 board 上放置…

软件设计,建模及需求分析

文章目录 设计原则建模及需求分析UML画图工具原型图画图工具 重构 设计原则 SOLID原则 单一职责 开闭 &#xff08;扩展开放&#xff0c;修改关闭&#xff09; 里氏替换 &#xff08;父类出现地方都可以用子类替换&#xff09; 接口隔离 依赖倒置&#xff08;高层模块不依…

理解dispatch_async

Submits a block for asynchronous execution on a dispatch queue and returns immediately. 提交一个块以在调度队列上异步执行并立即返回。 code showing 以一个最简单的demo开始 // 创建一个同步队列 dispatch_queue_t syncQueue dispatch_queue_create("io.sqi.My…

CSS之块浮动

在盒子模型的基础上就可以对网页进行设计 不知道盒子模型的可以看前面关于盒子模型的内容 而普通的网页设计具有一定的原始规律,这个原始规律就是文档流 文档流 标签在网页二维平面内默认的一种排序方式,块级标签不管怎么设置都会占一行,而同一行不能放置两个块级标签 行级…

Java面试八股之子类可以从父类继承哪些内容

Java子类可以从父类继承哪些内容 Java子类可以从父类继承以下内容&#xff1a; 属性&#xff08;Fields/Variables&#xff09;&#xff1a; public&#xff1a;子类可以继承父类所有的public修饰的属性。 protected&#xff1a;子类可以继承父类所有的protected修饰的属性…

1052 卖个萌(测试点1,2)

solution 想要输出\需要用\\才能输出&#xff0c;即 cout << "Are you kidding me? \\/" << endl;测试点1&#xff0c;2&#xff1a;输入序号小于1的非法情况 #include<iostream> #include<string> #include<map> using namespace…

XX食品有限公司智能制造汇报材料(71页PPT)

材料介绍&#xff1a; 本食品有限公司为应对市场需求变化&#xff0c;提高生产效率与产品质量&#xff0c;降低运营成本&#xff0c;特制定此智能制造规划。本规划旨在通过引入先进的智能制造技术和管理模式&#xff0c;推动公司向数字化、网络化、智能化方向发展&#xff0c;…

强烈推荐!Windows 11 24H2 版本系统下载(新功能多多)

微软向 Windows 11 Version 24H2 用户推送了 KB5036908 更新&#xff0c;标志着 24H2 版本的首次累积更新&#xff0c;更新后用户的系统版本号将升级至 26100.268。在新版本中&#xff0c;最显著的变化包括对文件资源管理器的改进、整合的 Copilot 功能、编辑 PNG 文件元数据的…

【WEB前端2024】3D智体编程:乔布斯3D纪念馆-第38课-密室逃脱

【WEB前端2024】3D智体编程&#xff1a;乔布斯3D纪念馆-第38课-密室逃脱 使用dtns.network德塔世界&#xff08;开源的智体世界引擎&#xff09;&#xff0c;策划和设计《乔布斯超大型的开源3D纪念馆》的系列教程。dtns.network是一款主要由JavaScript编写的智体世界引擎&…

echarts的toolbox自定义feature标签及事件

1. 需求 在使用echarts图时希望toolbox扩展一些自定义icon和点击事件&#xff0c;而不只是图中这些echarts提供的事件。 2. 文档 属性名类型描述toolbox.featureObject各工具配置项。 feature中除了echarts提供的各个内置的工具按钮外&#xff0c;可以自定义工具按钮。 除…

矩阵练习2

48.旋转图像 规律&#xff1a; 对于矩阵中第 i行的第 j 个元素&#xff0c;在旋转后&#xff0c;它出现在倒数第i 列的第 j 个位置。 matrix[col][n−row−1]matrix[row][col] 可以使用辅助数组&#xff0c;如果不想使用额外的内存&#xff0c;可以用一个临时变量 。 还可以通…

ShardingSphere跨表查询报错

目录 一、场景简介二、报错信息三、SQL四、原因五、解决方法一、调整SQL&#xff0c;不使用子查询方法二、将子查询的SQL独立出来&#xff0c;后续连接逻辑由代码处理 一、场景简介 1、使用ShardingSphere按月份进行分表 2、单月查询正常&#xff08;单表&#xff09; 3、跨…

苹果AI一夜颠覆所有,Siri史诗级进化,内挂GPT-4o

苹果AI一夜颠覆所有&#xff0c;Siri史诗级进化&#xff0c;内挂GPT-4o 刚刚&#xff0c;苹果AI&#xff0c;正式交卷&#xff01; 今天&#xff0c;苹果构建了一个全新AI帝国——个人化智能系统Apple Intelligence诞生&#xff0c;智能助手Siri迎来诞生13年以来的史诗级进化…

visual studio 2022使用全版本平台工具集

https://www.cnblogs.com/coolfan/p/15822057.html vs2022使用全版本平台工具集 关键词&#xff1a;visual studio 2022使用全版本平台工具集;vs2022使用vc60、vc6.0工具集;vs2022使用全部旧平台工具集 优点&#xff1a;用v60平台工具集编译出来的exe文件可以无依赖的运行在W…

Spring--Bean的作用域,生命周期

Bean的作用域 Bean的作用域有很多种&#xff0c;在Spring Framework中支持6种&#xff08;其中有四种只有在web环境中才能生效&#xff09;&#xff0c;同时Spring还支持自定义Bean的范围。 Spring Framework中支持的6种范围&#xff1a; 作用域解释singleton每个Spring IoC…

Manav Garg:生成式人工智能时代的SaaS

随着Chatgpt推动的人工智能时代精神席卷全球&#xff0c;它将如何影响SaaS世界&#xff1f;SaaS创业公司将如何适应这个新时代&#xff1f; 新兴市场在哪里&#xff1f;虽然这种技术平台的转变将带来巨大的机会&#xff0c;但传统的印度SaaS剧本必须适应新的人工智能秩序。创始…

误操作全盘重新分区?数据恢复与防范策略全解析

一、全盘重新分区概述 全盘重新分区&#xff0c;指的是对硬盘或存储设备上的所有分区进行删除并重新创建新分区的操作。这一操作通常会导致原有分区中的数据被清除&#xff0c;给用户带来数据丢失的风险。在某些情况下&#xff0c;用户可能由于误操作或软件故障而进行了全盘重…

【ArcGISProSDK】OpenItemDialog打开文件对话框

打开单个文件 效果 代码 public async void OpenFunction() {// 获取默认数据库var gdbPath Project.Current.DefaultGeodatabasePath;OpenItemDialog openItemDialog new OpenItemDialog() { Title "打开要素文件",InitialLocation gdbPath,Filter ItemFilte…

2024军民两用智能装备技术展会:领略“5G边缘计算器”开启智能化数据处理新篇章

"占星者5G边缘计算器&#xff1a;开启智能化数据处理新篇章" 随着物联网和人工智能技术的迅猛发展&#xff0c;数据处理的需求日益增长&#xff0c;对计算设备的性能提出了更高的要求。在“2024年中国军民两用智能装备与通信技术产业展览会”上&#xff0c;占星者5G边…

教育小程序开发:技术实现与实践案例

随着信息技术的不断进步&#xff0c;教育小程序在教育领域的应用越来越广泛。教育小程序开发不仅可以提高教学效率&#xff0c;还能够提供个性化的学习体验。本文将以技术代码为例&#xff0c;详细介绍教育小程序开发的关键技术和实践案例&#xff0c;帮助开发者更好地理解和实…