博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode - Interleaving String
阅读量:6714 次
发布时间:2019-06-25

本文共 1120 字,大约阅读时间需要 3 分钟。

Given s1, s2, s3, 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解决,dp[i][j]的状态表示为s1[0...i] + s2[0...j]的字符串区间是否能组成s3.//那么,动态转移方程为:// 1) s1[i-1] == s3[i+j-1] && dp[i-1][j] = true 那么,dp[i][j] = true;// 2) s2[j-1] == s3[i+j-1] && dp[i][j-1] = true 那么,dp[i][j] = true;class Solution {public:    bool isInterleave(std::string s1, std::string s2, std::string s3) {		if(s1.size() + s2.size() != s3.size()) return false;		std::vector
> dp(s1.size()+1,std::vector
(s2.size()+1,0)); dp[0][0] = 1; for (int i = 1; i < s1.size()+1; i++) { if(s1[i-1] == s3[i-1] && dp[i-1][0]) dp[i][0] = true; } for (int i = 1; i < s2.size()+1; i++) { if(s2[i-1] == s3[i-1] && dp[0][i-1]) dp[0][i] = true; } for (int i = 1; i < s1.size() + 1; i++) { for (int j = 1; j < s2.size() + 1; j++) { if(s1[i-1] == s3[i+j-1] && dp[i-1][j]) dp[i][j] = true; if(s2[j-1] == s3[i+j-1] && dp[i][j-1]) dp[i][j] = true; } } return dp[s1.size()][s2.size()]; }};

转载地址:http://nehlo.baihongyu.com/

你可能感兴趣的文章
centos6.4搭建zabbix
查看>>
Nginx+Keepalived实现
查看>>
安装python的easy_install和pip
查看>>
android SQLite
查看>>
Sublime Text 2 快捷键用法大全
查看>>
放弃redis使用mongodb做任务队列支持增删改管理
查看>>
G口与S口的区别
查看>>
甲骨文拒绝SAP 2.72亿美元赔偿要求重审
查看>>
我的友情链接
查看>>
linux非交互式生成秘钥
查看>>
SQL Server数据库镜像搭建(无见证无域控)
查看>>
C练习小代码-20151108
查看>>
Mac os X 10.11 sudo 指令出问题了么?
查看>>
互联网协议入门(2)
查看>>
DataSource的可配参数有哪些,有哪些DataSource可以用
查看>>
本地文件共享服务(nfs samba ftp)
查看>>
scp通过代理proxy传输文件
查看>>
数据段、代码段、堆栈段、BSS段的区别
查看>>
WebService之Axis2快速入门(5): 管理会话(Session)
查看>>
以太坊RPC接口使用
查看>>