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

leetcode第一刷_Interleaving String

时间:2014-05-09 06:16:48      阅读:232      评论:0      收藏:0      [点我收藏+]

标签:c++   leetcode   算法   

有关这种字符串的题真是层出不穷啊,而且他们都有这样一个特点,就是递归的思路如此简单,但一定超时!

这个时候,dp就朝我们缓缓走来。递归超,dp搞!这道题的状态转移方程还是比较好写的,用ispart[i][j]代表s1贡献i长,s2贡献j长时,能不能形成s3的前i+j个字符。更新可以按照行或者列开始,s3的前i+j个字符,可以是((i-1)+1)+j构成,也可以是i+((j-1)+1)构成,这取决于当前的这个字符s3[i+j-1]跟s1[i-1]和s2[j-1]是否相等,或的关系就可以解决问题。

边界条件也很好确定,就是当只有一个string参与构造时的情况,注意一旦有不相等的字符,那么后面的全都白搭。

class Solution {
public:
    bool isInterleave(string s1, string s2, string s3) {
        int l1 = s1.length(), l2 = s2.length(), l3 = s3.length();
        if(l3 != l1+l2) return false;
        bool ispart[l1+1][l2+1];
         memset(ispart, 0, sizeof(ispart));
        ispart[0][0] = 1;
        for(int i=0;i<l1;i++){
            if(s1[i] == s3[i])
                ispart[i+1][0] = 1;
            else
                break;
        }
        for(int i=0;i<l2;i++){
            if(s2[i] == s3[i])
                ispart[0][i+1] = 1;
            else
                break;
        }
        for(int i=1;i<=l1;i++){
            for(int j=1;j<=l2;j++){
                ispart[i][j] = (s1[i-1]==s3[i+j-1]&&ispart[i-1][j])||(s2[j-1]==s3[i+j-1]&&ispart[i][j-1]);
            }
        }
        return ispart[l1][l2];
    }
};


leetcode第一刷_Interleaving String,布布扣,bubuko.com

leetcode第一刷_Interleaving String

标签:c++   leetcode   算法   

原文地址:http://blog.csdn.net/u012792219/article/details/25341221

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