A. Train and Peter

题目连接:

http://www.codeforces.com/contest/8/problem/A

Description

Peter likes to travel by train. He likes it so much that on the train he falls asleep.

Once in summer Peter was going by train from city A to city B, and as usual, was sleeping. Then he woke up, started to look through the window and noticed that every railway station has a flag of a particular colour.

The boy started to memorize the order of the flags' colours that he had seen. But soon he fell asleep again. Unfortunately, he didn't sleep long, he woke up and went on memorizing the colours. Then he fell asleep again, and that time he slept till the end of the journey.

At the station he told his parents about what he was doing, and wrote two sequences of the colours that he had seen before and after his sleep, respectively.

Peter's parents know that their son likes to fantasize. They give you the list of the flags' colours at the stations that the train passes sequentially on the way from A to B, and ask you to find out if Peter could see those sequences on the way from A to B, or from B to A. Remember, please, that Peter had two periods of wakefulness.

Peter's parents put lowercase Latin letters for colours. The same letter stands for the same colour, different letters — for different colours.

Input

The input data contains three lines. The first line contains a non-empty string, whose length does not exceed 105, the string consists of lowercase Latin letters — the flags' colours at the stations on the way from A to B. On the way from B to A the train passes the same stations, but in reverse order.

The second line contains the sequence, written by Peter during the first period of wakefulness. The third line contains the sequence, written during the second period of wakefulness. Both sequences are non-empty, consist of lowercase Latin letters, and the length of each does not exceed 100 letters. Each of the sequences is written in chronological order.

Output

Output one of the four words without inverted commas:

«forward» — if Peter could see such sequences only on the way from A to B;

«backward» — if Peter could see such sequences on the way from B to A;

«both» — if Peter could see such sequences both on the way from A to B, and on the way from B to A;

«fantasy» — if Peter could not see such sequences.

Sample Input

atob

a

b

Sample Output

forward

Hint

题意

有一个人在坐火车,不知道从A到B的还是从B到A的

现在他迷迷糊糊睡了一觉,然后醒来,写下来他看到的字符,然后又迷迷糊糊睡了下去,然后又写下他看到的字符

现在给你这个从A到B的字符串,问这个人坐的火车从A到B还是从B到A的

题解:

首先正着做,暴力求KMP,求匹配的位置,如果存在s1串和s2串匹配的位置不重合的话,就说明合法

正着做一次,再反着做一次就好了

代码

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5+7;
char s[maxn],s1[maxn],s2[maxn];
int p[maxn];
vector<int>p1;
vector<int>p2;
int main()
{
scanf("%s",s+1);
scanf("%s",s1+1);
scanf("%s",s2+1);
int len=strlen(s1+1);
int j=0;
for(int i=2;i<=len;i++)
{
while(j>0&&s1[j+1]!=s1[i])j=p[j];
if(s1[j+1]==s1[i])j++;p[i]=j;
}
int len2=strlen(s+1);
j=0;
for(int i=1;i<=len2;i++)
{
while(j>0&&s1[j+1]!=s[i])j=p[j];
if(s1[j+1]==s[i])j++;
if(j==len){p1.push_back(i),j=p[j];}
}
len = strlen(s2+1);
j=0;
memset(p,0,sizeof(p));
for(int i=2;i<=len;i++)
{
while(j>0&&s2[j+1]!=s2[i])j=p[j];
if(s2[j+1]==s2[i])j++;p[i]=j;
}
j=0;
for(int i=1;i<=len2;i++)
{
while(j>0&&s2[j+1]!=s[i])j=p[j];
if(s2[j+1]==s[i])j++;
if(j==len){p2.push_back(i),j=p[j];}
}
sort(p1.begin(),p1.end());
sort(p2.begin(),p2.end());
int flag1 = 0,flag2 = 0;
if(p1.size()!=0&&p2.size()!=0)
if(p1[0]+strlen(s2+1)<=p2[p2.size()-1])flag1=1; p1.clear(),p2.clear();
reverse(s+1,s+1+len2); memset(p,0,sizeof(p));
len=strlen(s1+1);
j=0;
for(int i=2;i<=len;i++)
{
while(j>0&&s1[j+1]!=s1[i])j=p[j];
if(s1[j+1]==s1[i])j++;p[i]=j;
}
len2=strlen(s+1);
j=0;
for(int i=1;i<=len2;i++)
{
while(j>0&&s1[j+1]!=s[i])j=p[j];
if(s1[j+1]==s[i])j++;
if(j==len){p1.push_back(i),j=p[j];}
}
len = strlen(s2+1);
j=0;
memset(p,0,sizeof(p));
for(int i=2;i<=len;i++)
{
while(j>0&&s2[j+1]!=s2[i])j=p[j];
if(s2[j+1]==s2[i])j++;p[i]=j;
}
j=0;
for(int i=1;i<=len2;i++)
{
while(j>0&&s2[j+1]!=s[i])j=p[j];
if(s2[j+1]==s[i])j++;
if(j==len){p2.push_back(i),j=p[j];}
}
sort(p1.begin(),p1.end());
sort(p2.begin(),p2.end());
if(p1.size()!=0&&p2.size()!=0)
if(p1[0]+strlen(s2+1)<=p2[p2.size()-1])flag2=1; if(flag1&&flag2)
return puts("both"),0;
if(flag1)
return puts("forward"),0;
if(flag2)
return puts("backward"),0;
return puts("fantasy"),0; }

Codeforces Beta Round #8 A. Train and Peter KMP的更多相关文章

  1. Codeforces Beta Round #80 (Div. 2 Only)【ABCD】

    Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...

  2. Codeforces Beta Round #62 题解【ABCD】

    Codeforces Beta Round #62 A Irrational problem 题意 f(x) = x mod p1 mod p2 mod p3 mod p4 问你[a,b]中有多少个数 ...

  3. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

  4. Codeforces Beta Round #13 C. Sequence (DP)

    题目大意 给一个数列,长度不超过 5000,每次可以将其中的一个数加 1 或者减 1,问,最少需要多少次操作,才能使得这个数列单调不降 数列中每个数为 -109-109 中的一个数 做法分析 先这样考 ...

  5. Codeforces Beta Round #79 (Div. 2 Only)

    Codeforces Beta Round #79 (Div. 2 Only) http://codeforces.com/contest/102 A #include<bits/stdc++. ...

  6. Codeforces Beta Round #77 (Div. 2 Only)

    Codeforces Beta Round #77 (Div. 2 Only) http://codeforces.com/contest/96 A #include<bits/stdc++.h ...

  7. Codeforces Beta Round #76 (Div. 2 Only)

    Codeforces Beta Round #76 (Div. 2 Only) http://codeforces.com/contest/94 A #include<bits/stdc++.h ...

  8. Codeforces Beta Round #75 (Div. 2 Only)

    Codeforces Beta Round #75 (Div. 2 Only) http://codeforces.com/contest/92 A #include<iostream> ...

  9. Codeforces Beta Round #74 (Div. 2 Only)

    Codeforces Beta Round #74 (Div. 2 Only) http://codeforces.com/contest/90 A #include<iostream> ...

随机推荐

  1. 不相交集ADT--链表实现

    每一个集合用用一个链表来表示.链表的第一个对象作为它所在集合的代表.链表中每个对象都包含一个集合成员,一个指向下一个对象的指针,以及指向代表的指针.每个链表含head和tail指针,head指向链表的 ...

  2. Linux中fork()函数的底层实现【转】

    转自:http://blog.csdn.net/duoru_xiong/article/details/76358812 1. fork(),vfork(),clone()的区别 这三个系统调用的底层 ...

  3. awk正则匹配nginx日志【原创】

    查看网页访问代码不为200和30x所有行的内容 awk '{if($9!~/200|30*/) print $0}' /app/logs/http_access.log 或 awk '$9!~/200 ...

  4. mysql 创建数据库的时候选择 utf8 bin 和 utf8 ci的区别

    utf8 ci  不区分大小写: utf8 bin 区分大小写:

  5. 守护进程daemon函数

    #include  <unistd.h> int daemon(int nochdir,int noclose) 在创建精灵进程的时候,往往需要将精灵进程的工作目录修改为"/&q ...

  6. linux下C语言编程,include的默认搜索路径

    C语言编程时,发现细节的魅力很大.较为详细了看了一下关于include的知识,发现了几点新知: 1.include<头文件名>和include"头文件名" 如:incl ...

  7. 强大的PHP一句话后门

    强悍的PHP一句话后门  这类后门让网站.服务器管理员很是头疼,经常要换着方法进行各种检测,而很多新出现的编写技术,用普通的检测方法是没法发现并处理的. 今天我们细数一些有意思的PHP一句话木马. 1 ...

  8. CNN基础

    CNN一般结构 卷积层作用: 1) 提取不同维度的特征,组合不同维度特征,其本质是卷积核,因此,学习一个有效的总卷积核是训练卷积层主要工作 2)寻找不同位置,不同大小的特征 3) 根据卷积核参数计算上 ...

  9. Single Image Haze Removal(图像去雾)-CVPR’09 Best Paper

    公式推导 paper闪光点 找到了一个很简洁的假设. paper不足 代码跑起来很慢.据说2010年的ECCV那篇是改进的.

  10. 【hdoj_1042】N!(大数)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1042 题目说明待求阶乘的数最大为10000,而10000!的位数为35660(这个数是上网查的),所以已经 ...