码迷,mamicode.com
首页 > 其他好文 > 详细

97. Interleaving String Add to List

时间:2017-04-06 12:26:45      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:tab   cto   for   vector   str   解题思路   als   adb   nbsp   

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.

解题思路:很经典的一道DP题。table[i][j]表示字符串s1的位置位i,s2的位置位j时能否用s1[0..i-1],s2[0...j-1]拼成s3[0...i+j-1]。初始化时table[0][0]=1表示全都为空时,可以完成。

class Solution {
public:
    bool isInterleave(string s1, string s2, string s3) {
        if(s1.length()+s2.length()!=s3.length())return false;
        vector<vector<int> >table(s1.length()+1,vector<int>(s2.length()+1,0));
        for(int i=0;i<s1.length()+1;i++)
            for(int j=0;j<s2.length()+1;j++)
                if(i==0&&j==0)table[i][j]=1;
                else if(i==0)table[i][j]=(table[i][j-1]&&s2[j-1]==s3[j-1]);
                else if(j==0)table[i][j]=(table[i-1][j]&&s1[i-1]==s3[i-1]);
                else table[i][j]=table[i-1][j]&&s1[i-1]==s3[i+j-1]||table[i][j-1]&&s2[j-1]==s3[i+j-1];
        return table[s1.length()][s2.length()];
    }
};

 

97. Interleaving String Add to List

标签:tab   cto   for   vector   str   解题思路   als   adb   nbsp   

原文地址:http://www.cnblogs.com/tsunami-lj/p/6672817.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!