算法练习第五十三天|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;
    }
}
相关推荐
Hello.Reader12 分钟前
深入浅出 Adam 优化算法从直觉到公式
深度学习·算法
识君啊12 分钟前
拆分与合并的艺术·分治思想:Java归并排序深度解析
java·数据结构·算法·排序算法·归并排序·分治
Trouvaille ~13 分钟前
【贪心算法】专题(六):降维打击与错位重构的终极收官
c++·算法·leetcode·面试·贪心算法·重构·蓝桥杯
2301_8008951014 分钟前
dijkstra求最短路径--备考蓝桥杯版
算法
葡萄98917 分钟前
蓝桥杯k倍区间(前缀和、余数统计)
数据结构·算法
智者知已应修善业19 分钟前
【任何一个自然数m的立方均可写成m个连续奇数之和】2024-10-17
c语言·数据结构·c++·经验分享·笔记·算法
阿里嘎多哈基米29 分钟前
速通Hot100-Day07——栈
数据结构·算法·leetcode··队列·hot100
一叶落43829 分钟前
LeetCode 135. 分发糖果(C语言)| 贪心算法 + 双向遍历详解
c语言·数据结构·算法·leetcode·贪心算法·哈希算法
2401_9001515429 分钟前
自定义异常类设计
开发语言·c++·算法
努力学算法的蒟蒻30 分钟前
day113(3.15)——leetcode面试经典150
算法·leetcode·职场和发展