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

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. };

相关推荐

  1. 代码随想算法训练36DAY51

    2024-06-18 13:36:05       32 阅读
  2. 代码随想算法训练36DAY53

    2024-06-18 13:36:05       30 阅读
  3. 代码随想算法训练36DAY52

    2024-06-18 13:36:05       26 阅读
  4. 代码随想算法训练29Day30|LeetCode 332,51,37

    2024-06-18 13:36:05       56 阅读
  5. 代码随想算法训练29Day31|LeetCode 455,376,53

    2024-06-18 13:36:05       62 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-18 13:36:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-18 13:36:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-18 13:36:05       82 阅读
  4. Python语言-面向对象

    2024-06-18 13:36:05       91 阅读

热门阅读

  1. ABAP随笔记

    2024-06-18 13:36:05       54 阅读
  2. Android10 动态修改开机动画(三)命令说明

    2024-06-18 13:36:05       24 阅读
  3. PHP框架详解:Symfony框架讲解

    2024-06-18 13:36:05       38 阅读
  4. DDP、FDDP、BOXDDP算法概要

    2024-06-18 13:36:05       37 阅读
  5. JVM-GC-G1垃圾回收器

    2024-06-18 13:36:05       24 阅读
  6. PostgreSQL源码分析 —— FunctionScan

    2024-06-18 13:36:05       22 阅读
  7. mysql集群,两主两从,使用mysql-proxy实现读写分离

    2024-06-18 13:36:05       30 阅读
  8. MySQL WHERE子句的使用和优化方法

    2024-06-18 13:36:05       32 阅读
  9. 使用 MyBatis 日志插件实现日志记录

    2024-06-18 13:36:05       37 阅读