【28.57%】【codeforces 615C】 Running Track
time limit per test1 second
memory limit per test512 megabytes
inputstandard input
outputstandard output
A boy named Ayrat lives on planet AMI-1511. Each inhabitant of this planet has a talent. Specifically, Ayrat loves running, moreover, just running is not enough for him. He is dreaming of making running a real art.
First, he wants to construct the running track with coating t. On planet AMI-1511 the coating of the track is the sequence of colored blocks, where each block is denoted as the small English letter. Therefore, every coating can be treated as a string.
Unfortunately, blocks aren’t freely sold to non-business customers, but Ayrat found an infinite number of coatings s. Also, he has scissors and glue. Ayrat is going to buy some coatings s, then cut out from each of them exactly one continuous piece (substring) and glue it to the end of his track coating. Moreover, he may choose to flip this block before glueing it. Ayrat want’s to know the minimum number of coating s he needs to buy in order to get the coating t for his running track. Of course, he also want’s to know some way to achieve the answer.
Input
First line of the input contains the string s — the coating that is present in the shop. Second line contains the string t — the coating Ayrat wants to obtain. Both strings are non-empty, consist of only small English letters and their length doesn’t exceed 2100.
Output
The first line should contain the minimum needed number of coatings n or -1 if it’s impossible to create the desired coating.
If the answer is not -1, then the following n lines should contain two integers xi and yi — numbers of ending blocks in the corresponding piece. If xi ≤ yi then this piece is used in the regular order, and if xi > yi piece is used in the reversed order. Print the pieces in the order they should be glued to get the string t.
Examples
input
abc
cbaabc
output
2
3 1
1 3
input
aaabrytaaa
ayrat
output
3
1 1
6 5
8 7
input
ami
no
output
-1
Note
In the first sample string “cbaabc” = “cba” + “abc”.
In the second sample: “ayrat” = “a” + “yr” + “at”.
【题解】
把s1串的所有子串都加入到字典树;在每个节点记录这个节点在s1中的起始位置和终止位置;
加入的时候正串和反串都要加入(加入到同一颗字典树即可);
因为s1串可以多次使用;
所以我们让每次使用都达到最长的距离即可,这样肯定是最优的;
那个from和to域实在设计得巧妙;
从s2串的初始位置开始;从字典树的根节点开始走一条路径即可;
#include <cstdio>
#include <cmath>
#include <set>
#include <map>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <queue>
#include <vector>
#include <stack>
#include <string>
#define lson L,m,rt<<1
#define rson m+1,R,rt<<1|1
#define LL long long
using namespace std;
const int MAXN = 4500000;
const int MAXSIZE = 3000;
const int dx[5] = {0,1,-1,0,0};
const int dy[5] = {0,0,0,-1,1};
const double pi = acos(-1.0);
int tree1[MAXN][27],from[MAXN],to[MAXN];
int ans[MAXSIZE][2];
int cnt1 = 0,cnt2 = 0;
string s1,s2;
void add1(int pos,int len)
{
int now = 0;
for (int i = pos;i<=len-1;i++)
{
int key = s1[i]-'a'+1;
if (tree1[now][key])
{
now = tree1[now][key];
continue;
}
tree1[now][key]=++cnt1;
now = tree1[now][key];
from[now] = pos;to[now] = i;
}
}
void add2(int pos)
{
int now = 0;
for (int i = pos;i>=0;i--)
{
int key = s1[i]-'a'+1;
if (tree1[now][key])
{
now = tree1[now][key];
continue;
}
tree1[now][key]=++cnt1;
now = tree1[now][key];
from[now] = pos;to[now] =i;
}
}
int main()
{
//freopen("F:\\rush.txt","r",stdin);
cin >>s1;
cin >>s2;
int len1 = s1.size();
for (int i = 0;i <= len1-1;i++)
add1(i,len1);
for (int i = len1-1;i>=0;i--)
add2(i);
int now = 0;
int len2 = s2.size();
int dd = 0;
while (now<=len2-1)
{
int key = s2[now]-'a'+1;
//printf("%d\n",now);
int temp1 = 0,num1 =now;
while (num1<=len2-1 && tree1[temp1][key]!=0)
{
temp1 = tree1[temp1][key];
num1++;
key = s2[num1] - 'a'+1;
}
if (num1-1 < now)
{
puts("-1");
return 0;
}
else
{
dd++;
now = num1-1;
ans[dd][0] = from[temp1];
ans[dd][1] = to[temp1];
now++;
}
}
printf("%d\n",dd);
for (int i = 1;i <= dd;i++)
printf("%d %d\n",ans[i][0]+1,ans[i][1]+1);
return 0;
}
【28.57%】【codeforces 615C】 Running Track的更多相关文章
- 【28.57%】【codeforces 711E】ZS and The Birthday Paradox
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- 【 BowWow and the Timetable CodeForces - 1204A 】【思维】
题目链接 可以发现 十进制4 对应 二进制100 十进制16 对应 二进制10000 十进制64 对应 二进制1000000 可以发现每多两个零,4的次幂就增加1. 用string读入题目给定的二进制 ...
- 【57.97%】【codeforces Round #380A】Interview with Oleg
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【34.57%】【codeforces 557D】Vitaly and Cycle
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【75.28%】【codeforces 764B】Decoding
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【30.93%】【codeforces 558E】A Simple Task
time limit per test5 seconds memory limit per test512 megabytes inputstandard input outputstandard o ...
- 【77.78%】【codeforces 625C】K-special Tables
time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standa ...
- 【codeforces 760A】Petr and a calendar
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- 【codeforces 750C】New Year and Rating(做法2)
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
随机推荐
- Android实践 -- 监听应用程序的安装、卸载
监听应用程序的安装.卸载 在AndroidManifest.xml中注册一个静态广播,监听安装的广播 android.intent.action.PACKAGE_ADDED 监听程序卸载的广播 and ...
- POJ 1852 Ants || UVA 10881 - Piotr's Ants 经典的蚂蚁问题
两题很有趣挺经典的蚂蚁问题. 1.n只蚂蚁以1cm/s的速度在长为L的竿上爬行,当蚂蚁爬到竿子的端点就会掉落.当两只蚂蚁相撞时,只能各自反向爬回去.对于每只蚂蚁,给出距离左端的距离xi,但不知道它的朝 ...
- SQL Server 中计算农历
1.建一表,放初始化资料 因为农历的日期,是由天文学家推算出来的,到现在只有到2049年的,以后的有了还可以加入! CREATE TABLE SolarData ( yearId int no ...
- 【Codeforces Round #299 (Div. 2) B】Tavas and SaDDas
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 每次取出最小的数字,在后面加上一个4或一个7就好; 会发现最后的数字很少的. [代码] #include <bits/stdc ...
- item.imageInsets =
直接上代码: item.imageInsets = UIEdgeInsetsMake(6, 0, -6, 0);//设置图片居中 阅读全文 本文已收录于下面专栏: wanglixin1999 +关注 ...
- pppoe-环境下的mtu和mss
路由器上在宽带拨号高级设置页面会有设置数据包MTU的页面 数据包MTU(字节):1480 (默认是1480,如非必要,请勿修改) PPPoE/ADSL:1492 ,可以尝试修改为1492 MTU: M ...
- P2P网络借贷系统-核心功能-用户投标-业务讲解
用户投标是P2P网络借贷系统的核心功能,相对比较复杂,为了更好地梳理业务和技术实现思路,特地详细总结分析下. 输入:用户id-uid,标的id-lid,投标金额-amount 1.根据lid,获得贷款 ...
- 【23.48%】【codeforces 723C】Polycarp at the Radio
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- Android多线程研究(1)——线程基础及源码剖析
从今天起我们来看一下Android中的多线程的知识,Android入门容易,但是要完成一个完善的产品却不容易,让我们从线程开始一步步深入Android内部. 一.线程基础回顾 package com. ...
- IdentityServer4实战 - JWT Token Issuer 详解
原文:IdentityServer4实战 - JWT Token Issuer 详解 一.前言 本文为系列补坑之作,拖了许久决定先把坑填完. 下文演示所用代码采用的 IdentityServer4 版 ...