算法练习第五十三天|1143.最长公共子序列、1035.不相交的线、53. 最大子序和

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

1143.最长公共子序列

java 复制代码
class Solution {
    public int longestCommonSubsequence(String text1, String text2) {
        //确定dp数组(dp table)以及下标的含义
        /**
        
            dp[i][j]:长度为[0, i - 1]的字符串text1与长度为[0, j - 1]的字符串text2的最长公共子序列为dp[i][j]

         */

         int[][] dp = new int[text1.length() +1][text2.length()+1];
         /**
         初始化:dp[i][0] = dp[0][j] = 0;
         
          */

          for(int i = 1;i<=text1.length();i++){
            char char1 = text1.charAt(i-1);
            for(int j = 1;j<=text2.length();j++){
                char char2 = text2.charAt(j-1);
                if(char1 == char2){
                    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[text1.length()][text2.length()];
    }
}

1035.不相交的线

java 复制代码
class Solution {
    public int maxUncrossedLines(int[] nums1, int[] nums2) {


        /**
            此题和公共子序列题意相同,表达不同
        
         */

         int[][] dp  = new int[nums1.length+1][nums2.length+1];

         for(int i = 1;i<=nums1.length;i++){
            int a = nums1[i-1];
            for(int j = 1;j<=nums2.length;j++){
                int b = nums2[j-1];
                if(a == b){
                    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[nums1.length][nums2.length];
    }
}
  1. 最大子序和
java 复制代码
class Solution {
    // public int maxSubArray(int[] nums) {
    //     int result = Integer.MIN_VALUE;
    //     int sum = 0;
    //     for(int i = 0;i<nums.length;i++){
    //         sum += nums[i];
    //         result = sum>result ? sum : result;
    //         if(sum < 0) sum = 0;
    //                 }
    //     return result;
    // }

    public int maxSubArray(int[] nums) {
        //确定dp数组(dp table)以及下标的含义
        //dp[i]:包括下标i(以nums[i]为结尾)的最大连续子序列和为dp[i]

        if(nums.length == 0){
            return 0;
        }
        int[] dp = new int[nums.length+1];
        
        int result = nums[0];
        dp[0] = nums[0];

        for(int i = 1;i<nums.length;i++){
            dp[i] = Math.max(nums[i],dp[i-1] + nums[i]);
            if(dp[i] > result){
                result = dp[i];
            }
        }
        return result;
    }
}
相关推荐
henyaoyuancc14 分钟前
vla学习 富
人工智能·算法
Gyoku Mint1 小时前
机器学习×第五卷:线性回归入门——她不再模仿,而开始试着理解你
人工智能·python·算法·机器学习·pycharm·回归·线性回归
蒙奇D索大2 小时前
【数据结构】图论最短路径算法深度解析:从BFS基础到全算法综述
数据结构·算法·图论·广度优先·图搜索算法
trouvaille2 小时前
哈希数据结构的增强
算法·go
我不是小upper2 小时前
L1和L2核心区别 !!--part 2
人工智能·深度学习·算法·机器学习
liujing102329293 小时前
Day09_刷题niuke20250609
java·c++·算法
不7夜宵3 小时前
力扣热题100 k个一组反转链表题解
算法·leetcode·链表
蒟蒻小袁4 小时前
力扣面试150题--课程表
算法·leetcode·面试
闻缺陷则喜何志丹4 小时前
【动态规划】B4336 [中山市赛 2023] 永别|普及+
c++·算法·动态规划·洛谷