题解 | #藏宝图-动态规划和简单倒序#
藏宝图
http://www.nowcoder.com/practice/74475ee28edb497c8aa4f8c370f08c30
#include<stdio.h>
#include<string>
#include<vector>
using namespace std;
int main(void)
{
string long_str;
cin>>long_str;
int l = long_str.size();
string short_str;
cin>>short_str;
int s = short_str.size();
if(short_str=="") cout<<"Yes";
if(long_str.size()<short_str.size()) cout<<"No";
vector<int > dp(l+1);
dp[0] = 0;
for(int i=1;i<=l;i++)
{
if(short_str[dp[i-1]]==long_str[i-1])
dp[i] = dp[i-1]+1;
else
dp[i] = dp[i-1];
if(dp[i]==s)
{
cout<<"Yes";
return 0;
}
}
cout<<"No";
return 0;
}
//another simple method /* /* for(int i = l-1;i>=0;i--) { for(int k=i,j=s-1;k>=0;) { if(long_str[k]==short_str[j]) { k--; j--; } else { k--; }
if(j<0) //j==0,还剩一个字符
{
cout<<"Yes";
return 0;
}
}
}
*/
*/