LeetCode 97

除初始化第一行与第一列外,判断是否是T的条件为左或上为T且此位置的字母与S3对应位置的字母相同

代码:

cpp 复制代码
class Solution {
    public boolean isInterleave(String s1, String s2, String s3) {
         int m = s1.length(), n = s2.length();
        if (s3.length() != m + n) return false;
        // 动态规划,dp[i,j]表示s1前i字符能与s2前j字符组成s3前i+j个字符;
        boolean[][] dp = new boolean[m+1][n+1];
        dp[0][0] = true;
        for (int i = 1; i <= m && s1.charAt(i-1) == s3.charAt(i-1); i++) dp[i][0] = true; // 不相符直接终止
        for (int j = 1; j <= n && s2.charAt(j-1) == s3.charAt(j-1); j++) dp[0][j] = true; // 不相符直接终止
        for (int i = 1; i <= m; i++) {
            for (int j = 1; j <= n; j++) {
                dp[i][j] = (dp[i - 1][j] && s3.charAt(i + j - 1) == s1.charAt(i - 1))
                    || (dp[i][j - 1] && s3.charAt(i + j - 1) == s2.charAt(j - 1));
            }
        }
        return dp[m][n];


    }
}
相关推荐
小李小李快乐不已2 小时前
栈和堆理论基础
c++·算法·leetcode
core5122 小时前
CatBoost:自带“翻译官”的算法专家
算法·boost·catboost
YGGP2 小时前
【Golang】LeetCode 139. 单词拆分
算法·leetcode
wuguan_2 小时前
C#递推算法
算法·c#·递推算法
多米Domi0112 小时前
0x3f第14天 最长公共子序列
算法·深度优先
spssau3 小时前
正交试验设计全解析:从正交表生成到极差与方差分析
数据库·算法·机器学习
minhuan3 小时前
大模型应用:不减性能只减负担:大模型稀疏化技术全景与实践.36
大数据·人工智能·算法
爱学大树锯3 小时前
592 · 查找和替换模式
算法
爱学大树锯3 小时前
775 · 回文对
算法