算法系列--两个数组的dp问题(2)(上)

简介: 算法系列--两个数组的dp问题(2)

💕"往前走"💕

作者:Mylvzi

文章主要内容:算法系列–两个数组的dp问题(2)

大家好,今天为大家带来的是算法系列--两个数组的dp问题(2),今天的题目相较于(1)简单很多

1.交错字符串

链接:

https://leetcode.cn/problems/interleaving-string/description/

分析:

本题看起来和之前做过的题目有所不同,这里一共有三个字符串,但是实际上只有两个字符串,当s1字符串的位置和s2字符串的位置固定之后,s3也就固定了,所以我们只需研究s1,s2这两个字符串即可

  • 状态表示:两个子串这样的问题最常用的状态表示就是s1在[0,i]区间内xxxx,s2[0,j]区间内xxxx,本题也是.
    dp[i][j] : s1在[0,i]区间内的字符串和s2在[0,j]区间内的字符串能否拼接成s3
  • 状态转移方程的推导:往往是根据最后一个位置的状态划分,分析如下:
  1. s1[i] != s3[i + j] && s2[j] != s3[i + j],则根本无法拼接成s3–>false
  2. s1[i] == s3[i + j] || s2[j] == s3[i + j],只要其中有一个等于s3[i + j]就有可能拼接成s3,此时需要判断的是前一个位置能否拼接成s3,前一个位置成立,当前位置也成立;前一个位置不成立,当前位置也无法成立
  • 初始化:还是根据状态表示去进行初始化
    第一行:表示s1为空,则s1和s2要想拼接成s3,必须保证s2和s3完全相同
    第一列:表示s2为空,则s1和s2要想拼接成s3,必须保证s1和s3完全相同

    代码:
class Solution {
    public boolean isInterleave(String s1, String s2, String s3) {
        int m = s1.length(), n = s2.length();
        if(m + n != s3.length()) return false;
        s1 = " " + s1; s2 = " " + s2; s3 = " " + s3;
        boolean[][] dp = new boolean[m + 1][n + 1];
        dp[0][0] = true;// 初始化第一个位置
        for(int j = 1; j <= n; j++) {// 初始化第一行
            if(s2.charAt(j) == s3.charAt(j)) dp[0][j] = true;
            else break;
        }
        for(int i = 1; i <= m; i++) {// 初始化第一列
            if(s1.charAt(i) == s3.charAt(i)) dp[i][0] = true;
            else break;
        }
        // 填表
        for(int i = 1; i <= m; i++) {
            for(int j = 1; j <= n; j++) {
                dp[i][j] = (s1.charAt(i) == s3.charAt(i + j) && dp[i - 1][j]) 
                        || (s2.charAt(j) == s3.charAt(i + j) && dp[i][j - 1]);
            }
        }
        return dp[m][n];// 返回值
    }
}

算法系列--两个数组的dp问题(2)(下)https://developer.aliyun.com/article/1480833?spm=a2c6h.13148508.setting.17.361f4f0eyTL4lb



目录
相关文章
|
1月前
|
算法 测试技术
【算法】二分算法——寻找旋转排序数组中的最小值
【算法】二分算法——寻找旋转排序数组中的最小值
|
1月前
|
算法
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
|
1月前
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
26天前
|
算法
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
|
1月前
|
算法
【算法】模拟算法——外观数组(medium)
【算法】模拟算法——外观数组(medium)
|
1月前
|
算法
【算法】前缀和——除自身以外数组的乘积
【算法】前缀和——除自身以外数组的乘积
|
1月前
|
算法
【算法】前缀和——寻找数组的中心下标
【算法】前缀和——寻找数组的中心下标
|
1月前
|
算法 Java 索引
LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
28 0
|
1月前
|
存储 算法 Java
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
18 0
|
2月前
|
机器学习/深度学习 存储 算法
数据结构与算法:数组的操作
数据结构与算法:数组的操作