题解 | #藏宝图-动态规划和简单倒序#

藏宝图

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;
        }
    }
}
*/

*/

全部评论

相关推荐

贪食滴🐶:你说熟悉扣篮的底层原理,有过隔扣职业球员的实战经验吗
点赞 评论 收藏
分享
小红书 后端开发 总包n+8w+期权
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务