判断一个字符串是否是有其他两个字符串交错构成的(Interleaving String)

该博客探讨如何判断一个字符串是否由其他两个字符串交错构成,通过实例解释了动态规划和递归这两种方法的应用,例如s1='aabcc',s2='dbbca',并展示了它们在确定s3的有效性上的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

举个例子:
s1 = “aabcc”,
s2 = “dbbca”,

如果 s3 = “aadbbcbcac”, return true.
如果 s3 = “aadbbbaccc”, return false.

1、动态规划

  public  boolean isInterleave(String s1,String s2,String s3){
        int s1len=s1.length(),s2len=s2.length(),s3len=s3.length();
        if(s1len+s2len!=s3len)return false;
        boolean val[][]=new boolean[s1len+1][s2len+1];
        val[0][0]=true;
        for(int i=1;i<=s1len;i++){
            val[i][0]=val[i-1][0]&&s1.charAt(i-1)==s3.charAt(i-1);
        }
        for(int i=1;i<=s2len;i++){
            val[0][i]=val[0][i-1]&&s2.charAt(i-1)==s3.charAt(i-1);
        }
        for(int i=1;i<=s1len;i++){

            for(int j=1;j<=s2len;j++){
                    val[i][j]=(val[i][j-1]&&s2.charAt(j-1)==s3.charAt(i+j-1))||
                            (val[i-1][j]&&s1.charAt(i-1)==s3.charAt(i+j-1));
            }
        }

        return val[s1len][s2len];
    }

2、递归

public boolean isInterleave(String s1, String s2, String s3) {
        if (s1.length() + s2.length() != s3.length()) return false;
       HashSet<Integer> cache = new HashSet<Integer>();
        return isInterleave0(s1, s2, s3, 0, 0,cache);
    }

    public  boolean isInterleave0(String s1, String s2, String s3, int p1, int p2,HashSet<Integer> cache) {
        if (p1 + p2 == s3.length())
            return true;
       if (cache.contains(p1 * s3.length() + p2))
            return false;
        // no need to store actual result.
        // if we found the path, we have already terminated.
        cache.add(p1 * s3.length() + p2);
        boolean match1 = p1 < s1.length() && s3.charAt(p1 + p2) == s1.charAt(p1);
        boolean match2 = p2 < s2.length() && s3.charAt(p1 + p2) == s2.charAt(p2);
        if (match1 && match2)
            return isInterleave0(s1, s2, s3, p1 + 1, p2,cache) ||
                   isInterleave0(s1, s2, s3, p1, p2 + 1,cache);
        else if (match1)
            return isInterleave0(s1, s2, s3, p1 + 1, p2,cache);
        else if (match2)
            return isInterleave0(s1, s2, s3, p1, p2 + 1,cache);
        else
            return false;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值