Interleaving String

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.

可以用递归做,每匹配s1或者s2中任意一个就递归下去。但是会超时。

因此考虑用动态规划做。

s1, s2只有两个字符串,因此可以展平为一个二维地图,判断是否能从左上角走到右下角。

当s1到达第i个元素,s2到达第j个元素:

地图上往右一步就是s2[j-1]匹配s3[i+j-1]。

地图上往下一步就是s1[i-1]匹配s3[i+j-1]。

示例:s1="aa",s2="ab",s3="aaba"。标1的为可行。最终返回右下角。

0  a  b

0   1  1  0

a   1  1  1

a   1  0  1

class Solution {
public:
bool isInterleave(string s1, string s2, string s3) {
int m = s1.size();
int n = s2.size();
if(m+n != s3.size())
return false;
vector<vector<bool> > path(m+, vector<bool>(n+, false));
for(int i = ; i < m+; i ++)
{
for(int j = ; j < n+; j ++)
{
if(i == && j == )
// start
path[i][j] = true;
else if(i == )
path[i][j] = path[i][j-] & (s2[j-]==s3[j-]);
else if(j == )
path[i][j] = path[i-][j] & (s1[i-]==s3[i-]);
else
path[i][j] = (path[i][j-] & (s2[j-]==s3[i+j-])) || (path[i-][j] & (s1[i-]==s3[i+j-]));
}
}
return path[m][n];
}
};

最新文章

  1. Docker应用程序容器技术_转
  2. Julius JS – 最流行的网页语音识别库
  3. windows下调用外部exe程序 SHELLEXECUTEINFO
  4. 【Android】Android内存机制,了解Android堆和栈
  5. 为什么C++类定义中,数据成员不能被指定为自身类型,但可以是指向自身类型的指针或引用?为什么在类体内可以定义将静态成员声明为其所属类的类型呢 ?
  6. Android 基于google Zxing实现二维码、条形码扫描,仿微信二维码扫描效果
  7. css text-overflow溢出文本显示省略号
  8. Stream To String , String To Stream
  9. python----------进程、线程、协程
  10. 你好,C++(2)1.3 C++世界版图1.4 如何学好C++
  11. 提取所有mtk机型的线刷包
  12. 技术是容易学会的(Copy)
  13. hdu3415(单调队列)
  14. HTML5 CSS3专题 纯CSS打造相冊效果
  15. javaWEB总结(1):第一个servlet程序
  16. centos7安装部署gitlab服务器
  17. 13 SQLiteOpenHelper SQLiteDatabase详解
  18. 景观指数分析 - 初识FragStats4.2
  19. 【c#】RabbitMQ学习文档(六)RPC(远程调用)
  20. 多态 与 鸭子类型 duck duck duck

热门文章

  1. iOS开发系列--音频播放、录音、
  2. 关于arcgi s_api_for_flex的总结
  3. Gridview数据导出excel时身份证号码为科学计数法的解决方法
  4. CentOS 7安装ifconfig
  5. CentOS 6.9/7通过yum安装指定版本的PostgreSQL扩展PostGIS
  6. OpenVPN Server端配置文件详细说明(转)
  7. How to implement *All-Digital* analog-to-digital converters in FPGAs and ASICs
  8. win7 系统装SQLServer2000 成功
  9. TYVJ 2002 扑克牌 题解
  10. Nicescroll滚动条插件的用法