leetcode第一刷_Interleaving String
2014-05-08 22:42
344 查看
有关这种字符串的题真是层出不穷啊,而且他们都有这样一个特点,就是递归的思路如此简单,但一定超时!
这个时候,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参与构造时的情况,注意一旦有不相等的字符,那么后面的全都白搭。
这个时候,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]; } };
相关文章推荐
- C#获取磁盘列表与信息
- Linux利用i节点删除乱码文件
- HDOJ 1874 畅通工程续
- c#中调用存储过程返回表的分页数据及总记录个数
- 关于jQuery链式操作
- JavaScript也能求爱哦
- java开发必备利器
- memcpy函数
- LogStash日志分析系统
- jquery链式操作
- How to fix this issue: Type Coercion failed: cannot convert flash.events::Event@8eda061 to starling.
- 经典书Discrete.Mathematics上的大神
- 软件工程之安卓小程序
- ubuntu忘记root密码的解决办法
- vs2010+opencv调试
- vc 浮点数转换为内存十六进制字符串
- 20060602-Cell segmentation
- Shell Script(1)----variable compare
- 冲刺周期会议九
- C#面向对象基于winform的扫雷游戏和简单的算法改进