编程练习(第十一周)

题目来源:https://leetcode.com

97. Interleaving String

  • Total Accepted: 67459
  • Total Submissions: 277962
  • Difficulty: Hard
  • Contributor: LeetCode

Given s1s2s3, find whether s3 is formed by the interleaving of s1 and s2.

For example,
Given:
s1 = "aabcc",
s2 = "dbbca",

When s3 = "aadbbcbcac", return true.
When s3 = "aadbbbaccc", return false.

Subscribe to see which companies asked this question.


题解:

    bool isInterleave(string s1, string s2, string s3) {
        int n1=s1.size(),n2=s2.size(),n3=s3.size();
        if(n1+n2!=n3) return false;
        vector<int> mp(255,0);
        for(int i=0;i<n1;i++) mp[s1[i]]++;
        for(int i=0;i<n2;i++) mp[s2[i]]++;
        for(int i=0;i<n3;i++){
            mp[s3[i]]--;
            if(mp[s3[i]]<0) return false;
        }
        vector<vector<int> >dp(n1+1,vector<int>(n2+1,0));
        dp[0][0] = 1;
        for(int len = 1;len<=n3;len++){
            for(int l=max(0,len-n2);l<=len&&l<=n1;l++){
                if(l>0 && s1[l-1]==s3[len-1]) dp[l][len-l] |= dp[l-1][len-l];
                if(len-l>0 && s2[len-l-1]==s3[len-1]) dp[l][len-l] |= dp[l][len-l-1];
            }
        }
        return dp[n1][n2]==1;
    }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值