Java中等题-交错字符串(力扣)

给定三个字符串 s1s2s3,请你帮忙验证 s3 是否是由 s1s2交错组成的。

两个字符串 st 交错 的定义与过程如下,其中每个字符串都会被分割成若干 非空

子字符串

  • s = s1 + s2 + ... + sn
  • t = t1 + t2 + ... + tm
  • |n - m| <= 1
  • 交错s1 + t1 + s2 + t2 + s3 + t3 + ... 或者 t1 + s1 + t2 + s2 + t3 + s3 + ...

注意: a + b 意味着字符串 ab 连接。

复制代码
输入:s1 = "aabcc", s2 = "dbbca", s3 = "aadbbcbcac"
输出:true

示例 2:

复制代码
输入:s1 = "aabcc", s2 = "dbbca", s3 = "aadbbbaccc"
输出:false

示例 3:

复制代码
输入:s1 = "", s2 = "", s3 = ""
输出:true

这道题有一些很容易错的地方,比如使用双指针就会出错

这道题要使用动态规划(建议大家自己去力扣看看详细题解)

这道题我没有思路,我看了官方题解之后,理解以后,自己写了一遍:

java 复制代码
class Solution {
    public boolean isInterleave(String s1, String s2, String s3) {
        int n1=s1.length();
        int n2=s2.length();
        int n3=s3.length();
        if(n1+n2!=n3){
            return false;
        }

        boolean f[][]=new boolean[n1+1][n2+1];
        f[0][0]=true;
       for(int i=0;i<=n1;i++){
           for(int j=0;j<=n2;j++){
               int p=i+j-1;
             if(i>0){
                 f[i][j]=f[i][j]||f[i-1][j]&&s1.charAt(i-1)==s3.charAt(p);
             }
             if(j>0){
                 f[i][j]=f[i][j]||f[i][j-1]&&s2.charAt(j-1)==s3.charAt(p);
             }
           }
       }

       return f[n1][n2];


    }
}

这道题还可以用滚动数组进行优化

java 复制代码
class Solution {
    public boolean isInterleave(String s1, String s2, String s3) {
        int n = s1.length(), m = s2.length(), t = s3.length();

        if (n + m != t) {
            return false;
        }

        boolean[] f = new boolean[m + 1];

        f[0] = true;
        for (int i = 0; i <= n; ++i) {
            for (int j = 0; j <= m; ++j) {
                int p = i + j - 1;
                if (i > 0) {
                    f[j] = f[j] && s1.charAt(i - 1) == s3.charAt(p);
                }
                if (j > 0) {
                    f[j] = f[j] || (f[j - 1] && s2.charAt(j - 1) == s3.charAt(p));
                }
            }
        }

        return f[m];
    }
}

作者:力扣官方题解
链接:https://leetcode.cn/problems/interleaving-string/solutions/335373/jiao-cuo-zi-fu-chuan-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

注意:滚定数组非常重要,不知道的朋友可以自己去看看

相关推荐
cynicme2 分钟前
力扣3318——计算子数组的 x-sum I(偷懒版)
java·算法·leetcode
青云交1 小时前
Java 大视界 -- Java 大数据在智能教育学习效果评估与教学质量改进实战
java·实时分析·生成式 ai·个性化教学·智能教育·学习效果评估·教学质量改进
崎岖Qiu1 小时前
【设计模式笔记17】:单例模式1-模式分析
java·笔记·单例模式·设计模式
Lei活在当下2 小时前
【现代 Android APP 架构】09. 聊一聊依赖注入在 Android 开发中的应用
java·架构·android jetpack
不穿格子的程序员2 小时前
从零开始刷算法-栈-括号匹配
java·开发语言·
lkbhua莱克瓦242 小时前
Java练习-正则表达式 1
java·笔记·正则表达式·github
yue0082 小时前
C#类继承
java·开发语言·c#
im_AMBER3 小时前
算法笔记 09
c语言·数据结构·c++·笔记·学习·算法·排序算法
凯芸呢3 小时前
Java中的数组(续)
java·开发语言·数据结构·算法·青少年编程·排序算法·idea
竹竹零3 小时前
JacksonUtil--序列化与反序列化
java·开发语言·windows