首页 > 其他 > 详细

97. 交错字符串. dp

时间:2020-07-21 00:43:24      阅读:94      评论:0      收藏:0      [点我收藏+]

给定三个字符串?s1, s2, s3, 验证?s3?是否是由?s1?和?s2 交错组成的。

示例 1:

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

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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/interleaving-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {
public:
    bool isInterleave(string s1, string s2, string s3) {
        int n = s1.size();
        int m = s2.size();
        int t = s3.size();

        //dp[i][j] : s1的前i个与s2的前j个字符能否构成s3的前i+j
        vector <vector<int>> dp = vector (n + 1, vector<int> (m + 1, false));

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

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

        return dp[n][m];
    }
};

97. 交错字符串. dp

原文:https://www.cnblogs.com/xgbt/p/13348108.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!