JAVA学习-练习试用Java实现“交错字符串”

问题:


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

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

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 意味着字符串 a 和 b 连接。

示例 1:

输入:s1 = "aabcc", s2 = "dbbca", s3 = "aadbbcbcac"
输出:true
示例 2:

输入:s1 = "aabcc", s2 = "dbbca", s3 = "aadbbbaccc"
输出:false
示例 3:

输入:s1 = "", s2 = "", s3 = ""
输出:true
提示:

0 <= s1.length, s2.length <= 100
0 <= s3.length <= 200
s1、s2、和 s3 都由小写英文字母组成

 

解答思路:

以下是使用 Java 语言实现交错字符串问题的代码:

```java

public class InterleavedStrings {

    public static boolean isInterleave(String s1, String s2, String s3) {

        int len1 = s1.length();

        int len2 = s2.length();

        int len3 = s3.length();

 

        // 如果三个字符串的长度不满足交错的条件,直接返回false

        if (len1 + len2!= len3) {

            return false;

        }

 

        // 创建一个二维布尔数组 dp,用于记录 s1 和 s2 的字符在 s3 中的匹配情况

        boolean[][] dp = new boolean[len1 + 1][len2 + 1];

 

        // 初始化 dp 数组的边界情况

        dp[0][0] = true;

        for (int i = 1; i <= len1; i++) {

            if (s1.charAt(i - 1) == s3.charAt(i - 1)) {

                dp[i][0] = dp[i - 1][0];

            }

        }

        for (int j = 1; j <= len2; j++) {

            if (s2.charAt(j - 1) == s3.charAt(j - 1)) {

                dp[0][j] = dp[0][j - 1];

            }

        }

 

        // 通过动态规划的方式填充 dp 数组

        for (int i = 1; i <= len1; i++) {

            for (int j = 1; j <= len2; j++) {

                dp[i][j] = (s1.charAt(i - 1) == s3.charAt(i + j - 1) && dp[i - 1][j]) ||

                           (s2.charAt(j - 1) == s3.charAt(i + j - 1) && dp[i][j - 1]);

            }

        }

 

        return dp[len1][len2];

    }

 

    public static void main(String[] args) {

        String s1 = "aabcc";

        String s2 = "dbbca";

        String s3 = "aadbbcbcac";

        boolean result = isInterleave(s1, s2, s3);

        System.out.println(result);

    }

}

```

这段代码定义了一个名为'isInterleave'的方法,它接受三个字符串's1'、's2'和's3'作为参数,并返回一个布尔值表示's3'是否可以由's1'和's2'交错组成。

在方法内部,首先检查三个字符串的长度是否满足交错的条件。然后创建一个二维布尔数组'dp',用于记录's1'和's2'的字符在's3'中的匹配情况。通过双重循环遍历's1'和's2',根据当前字符是否与's3'中的对应字符相等,以及之前的匹配情况来更新'dp'数组。

最后,在'main'方法中进行示例的调用和结果的输出。

(文章为作者在学习java过程中的一些个人体会总结和借鉴,如有不当、错误的地方,请各位大佬批评指正,定当努力改正,如有侵权请联系作者删帖。)

 

 

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值