算法练习第五十三天|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;
    }
}
相关推荐
WWZZ20251 小时前
ORB_SLAM2原理及代码解析:SetPose() 函数
人工智能·opencv·算法·计算机视觉·机器人·自动驾驶
小马学嵌入式~2 小时前
堆排序原理与实现详解
开发语言·数据结构·学习·算法
青岛少儿编程-王老师2 小时前
CCF编程能力等级认证GESP—C++6级—20250927
java·c++·算法
一人の梅雨2 小时前
1688 拍立淘接口深度开发:从图像识别到供应链匹配的技术实现
人工智能·算法·计算机视觉
Miraitowa_cheems3 小时前
LeetCode算法日记 - Day 64: 岛屿的最大面积、被围绕的区域
java·算法·leetcode·决策树·职场和发展·深度优先·推荐算法
Christo33 小时前
关于K-means和FCM的凸性问题讨论
人工智能·算法·机器学习·数据挖掘·kmeans
_不会dp不改名_3 小时前
leetcode_1382 将二叉搜索树变平衡树
算法·leetcode·职场和发展
greentea_20134 小时前
Codeforces Round 173 B. Digits(2043)
c++·算法
m0_743106465 小时前
LOBE-GS:分块&致密化效率提升
人工智能·算法·计算机视觉·3d·几何学
徐子童5 小时前
优选算法---字符串
java·算法·字符串·笔试·高精度相乘