前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Educational Codeforces Round 81 (Rated for Div. 2) C.Obtain The String

Educational Codeforces Round 81 (Rated for Div. 2) C.Obtain The String

作者头像
glm233
发布2020-09-28 11:15:56
2510
发布2020-09-28 11:15:56
举报

题目链接

题意:串S,T,T是目标串,你需要将一个空串变成T,通过将S的任意子串添加到这个要变成T的串后头,这里的子串可以是不连续的,问最少次数,做不到就-1

讲道理做这种题目没技巧,就是很直接,但是要认真分析出来,你要添加一个字符就去S里找最早出现的嘛,贪心很好理解,然后下一个字符看看有没有在这个最早出现位置的后头,要是有,ok接着如上操作否则答案+1,无解的情况很简单就是没有这个字符嘛

这样还不够要是极端样例会卡不过,很明显要用二分查找,就是先遍历一遍字符串找出每个字母的出现下标位置,这样就保证每一个字母出现位置都是有序的,就可以快速查找,嗯差不多就这样,详见代码

代码语言:javascript
复制
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define rg register ll
int main()
{
    ll n;
    cin>>n;
    for(rg i=1;i<=n;i++)
    {
        string s,t;
        vector<ll>v[30];
        cin>>s>>t;
        for(rg j=0;s[j];j++)
        {
            v[s[j]-'a'].push_back(j);
        }
        ll ans=1,tep=-1;
        for(rg j=0;t[j];j++)
        {
            ll k=t[j]-'a';
            if(!v[k].size())
            {
                ans=-1;
                break;
            }
            else
            {
                if(v[k][v[k].size()-1]>tep)
                {
                    //cout<<*upper_bound(v[k].begin(),v[k].end(),tep)<<endl;
                    tep=v[k][upper_bound(v[k].begin(),v[k].end(),tep)-v[k].begin()];
                }
                else ans++,tep=v[k][0];
            }
        }
        cout<<ans<<endl;
    }
    while(1)getchar();
    return 0;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-02-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档