leetcode第一刷_Interleaving String

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

这个时候,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

时间: 2024-07-30 12:14:32

leetcode第一刷_Interleaving String的相关文章

leetcode第一刷_Scramble String

字符串的好题.题干解释的非常复杂,一下让人不知所措了. 这道题到底是什么意思呢?最终的结果是把一个字符串中字母的顺序打乱了,让你判断一个字符串能不能由另一个字符串打乱得到.那打乱这个过程是怎么做的呢,很简单,给你一个字符串,你必须先找一个点把它砍成两半,你可以通过交换这两半的顺序来打乱源字符串的顺序,也就是在两半中的字符与另一半中所有字符的相对顺序是统一的.对于每一半,都可以重复上面的过程. 那想一下,怎么知道打断的那个点在哪呢?穷举.怎么知道打断之后有没有做交换操作呢?两种情况递归,有一条走的

leetcode第一刷_Decode Ways

这道题还挺难的.递归的思路是好想,不过不出意料的超时了. dp嘛.想一下i-1的编码加上第i个编码会怎样,如果加上的这个编码不是0,那么这一位可以独立解码,那长为i的解码个数至少是长为i-1的解码个数.还有呢?如果i-1位是1,可以把i-1位和i位同时解码出来,还有呢?如果i-1位是2而i位是0-6中的数字,也可以同时解码这两位编码.满足这个条件的时候,当前长度的解码个数还要加上i-2时的解码个数. 完全可以用一个数组存放过去的结果,但是很明显,当前的结论只与前一个和前前一个结果有关系.只要用三

leetcode第一刷_Permutation Sequence

这道题还挺好的,如果你的思路是每次生成一个全排列,然后累计到k次,那么停下来吧,肯定超时了亲.. 微软今年的笔试题里有一道类似的,我之前已经提到过了,是只有0和1的字符串,求第k个排列是什么样子的.这道题比那个要难一些,但是总体的思路是一样的.假设有n个数要组成排列,求第k个排列.像填表一样,从高位往地位,逐个填写.先考虑有n-1个数要组成排列,最多有(n-1)!种情况,当第n个数加入后,第n个数可以是从1增加到n的,没增加1,所包含的全排列数就会增加(n-1)!,因此,如果用k/(n-1)!,

leetcode第一刷_Word Ladder II

注:本文仅供技术探讨, 研究,测试使用. 这个漏洞是2014年2月4日被发现的, 因为该组件试用范围非常广, 所以该漏洞的影响也非常巨大.通过特制的包含畸形header的http请求,可以导致使用该组件的应用程序进入无限循环从而耗尽CPU等资源并最终崩溃. 最近因为在修补struts1的可操纵classLoader的漏洞(struts2也有该漏洞, 不在本文讨论范围), 所以我就在我建立的struts1的项目上直接做测试,怎么创建struts1的项目不在本文讨论范围之列你可以在这里下载strut

leetcode第一刷_Edit Distance

最小编辑距离,很经典的问题,今年微软实习生的笔试有一个这个的扩展版,牵扯到模板之类的,当时一行代码也没写出来.. dp可以很优雅的解决这个问题,状态转移方程也很明确.用pos[i][j]表示word1的前i个字符与word2的前j个字符之间的编辑距离.如果word[i-1]与word[j-1]相等,那pos[i][j]与pos[i-1][j-1]相等,否则的话,根据编辑的几种操作,可以从三种情况中选取代价最小的一种,从word1中删除一个字符?从word2中删除一个字符?修改其中一个?边界也很简

leetcode第一刷_Simplify Path

这道题的思路还是比较清晰的,用栈嘛,麻烦是麻烦在这些层次的细节上.主要有下面几个: ./和/:当前路径,遇到这种,应该将后面的文件夹或文件入栈. ../:上一层路径,遇到这种,应该做一次出栈操作,相当于返回了上一层目录. //:可以直接简化成'/'. 还有下面几个要注意的测试用例: 1. linux的路径名可以含有很多特殊字符,比如"_",".","*"等等,所以要特别注意含有"."的哪些路径名. 2. 在路径最后的..和.是

leetcode第一刷_Text Justification

这个题的接受率好低,搞得我一直不敢做.后来认真的看了一下题目,不是很难嘛,字符串的题目ac率就是低,除了难,还因为它的测试用例太多. 思路不难,主要是因为特殊情况太多.纯模拟,我把所有的情况罗列一下,仔细一点的话就能写好了. 1. 当word为空,也就是""时,应该返回一行跟L数目相等的空格.这种情况需要提前判断和处理. 2. 当当前行不是最后一行时,应该尽可能多的放单词,单词不能截断,在这一行上,单词应该分布的尽可能均匀,且要把这一行填满,效果就跟word排版里面的撑满整行很像.怎样

leetcode第一刷_Minimum Window Substring

好题,字符串,线性时间. 我觉得第一次拿到这个题的人应该不会知道该怎么做吧,要么就是我太弱了..先搞清楚这个题要求的是什么.从一个长字符串中找一个字串,这个字串中的字符完全包含了另一个给定目标串中的字符,且这个字串的长度要求最小.还有一个非常重要的简化,题干指明了要求这种最短字串只有一个,这个限制其实暗示了这道题的整体思路,只要找到一个长串,然后缩减到不能缩减即可. 从题目的要求出发可以发现,这道题对于字符串中字符的顺序是没有要求的,因此可以很自然的想到用hash表来保存目标串中的每个字符的个数

leetcode第一刷_Count and Say

水题. 描写叙述的还挺麻烦的,实际上就是纸老虎,用两个string,一个存上一轮的结果,一个用来更新出这一轮的结果,每次扫描上一轮,统计一个字符出现的次数,然后把这个次数和字符增加到这一轮的字符串中就能够了. class Solution { public: string countAndSay(int n) { if(n == 0) return ""; string tpres, res = "1"; for(int i=1;i<n;i++){ int j