算法系列--两个数组的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



目录
相关文章
|
3月前
|
人工智能 移动开发 算法
【动态规划】【C++算法】LeetCoce996正方形数组的数目
【动态规划】【C++算法】LeetCoce996正方形数组的数目
|
3月前
|
算法 测试技术 C++
【动态规划】【滑动窗口】【C++算法】 629K 个逆序对数组
【动态规划】【滑动窗口】【C++算法】 629K 个逆序对数组
|
2月前
|
算法 索引 Python
Python3实现旋转数组的3种算法
Python3实现旋转数组的3种算法
24 0
|
3月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-49 算法训练 寻找数组中最大值
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-49 算法训练 寻找数组中最大值
37 0
|
3天前
|
存储 算法 Java
数据结构与算法 数组和链表
数据结构与算法 数组和链表
8 0
|
7天前
|
存储 算法
Leetcode 30天高效刷数据结构和算法 Day1 两数之和 —— 无序数组
给定一个无序整数数组和目标值,找出数组中和为目标值的两个数的下标。要求不重复且可按任意顺序返回。示例:输入nums = [2,7,11,15], target = 9,输出[0,1]。暴力解法时间复杂度O(n²),优化解法利用哈希表实现,时间复杂度O(n)。
19 0
|
26天前
|
算法 JavaScript 前端开发
贪心算法】按要求补齐数组
贪心算法】按要求补齐数组
9 0
|
1月前
|
算法
算法系列--两个数组的dp问题(2)(下)
算法系列--两个数组的dp问题(2)(下)
20 0
|
1月前
|
存储 算法
算法系列--动态规划--⼦数组、⼦串系列(数组中连续的⼀段)(1)(下)
算法系列--动态规划--⼦数组、⼦串系列(数组中连续的⼀段)(1)
19 0
|
1月前
|
算法
算法系列--动态规划--⼦数组、⼦串系列(数组中连续的⼀段)(1)(上)
算法系列--动态规划--⼦数组、⼦串系列(数组中连续的⼀段)(1)
22 0