国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Oulipo POJ - 3461

2019-11-14 11:11:22
字體:
來源:轉載
供稿:網友

The French author Georges Perec (1936–1982) once wrote a book, La disparition, without the letter'e'. He was a member of the Oulipo group. A quote from the book:

Tout avait Pair normal, mais tout s’affirmait faux. Tout avait Fair normal, d’abord, puis surgissait l’inhumain, l’affolant. Il aurait voulu savoir où s’articulait l’association qui l’unissait au roman : stir son tapis, assaillant à tout instant son imagination, l’intuition d’un tabou, la vision d’un mal obscur, d’un quoi vacant, d’un non-dit : la vision, l’avision d’un oubli commandant tout, où s’abolissait la raison : tout avait l’air normal mais…

Perec would PRobably have scored high (or rather, low) in the following contest. People are asked to write a perhaps even meaningful text on some subject with as few occurrences of a given “Word” as possible. Our task is to provide the jury with a program that counts these occurrences, in order to obtain a ranking of the competitors. These competitors often write very long texts with nonsense meaning; a sequence of 500,000 consecutive'T's is not unusual. And they never use spaces.

So we want to quickly find out how often a word, i.e., a given string, occurs in a text. More formally: given the alphabet {'A','B','C', …,'Z'} and two finite strings over that alphabet, a wordW and a textT, count the number of occurrences ofW inT. All the consecutive characters of W must exactly match consecutive characters ofT. Occurrences may overlap.

Input

The first line of the input file contains a single number: the number of test cases to follow. Each test case has the following format:

One line with the word W, a string over {'A','B','C', …,'Z'}, with 1 ≤ |W| ≤ 10,000 (here |W| denotes the length of the string W).One line with the text T, a string over {'A','B','C', …,'Z'}, with |W| ≤ |T| ≤ 1,000,000.Output

For every test case in the input file, the output should contain a single number, on a single line: the number of occurrences of the wordW in the textT.

Sample Input
3BAPCBAPCAZAAZAZAZAVERDIAVERDXIVYERDIANSample Output
130KMP問題。。。。不過和KMP稍有不同,這個題要求計算次數而不是匹配成功就可以,所以next數組多求一位。AC代碼:
#include <iostream>#include <stdio.h>#include <string.h>#include <math.h>#include <algorithm>using namespace std;int lent,lenp,next[10005];char p[10005],t[1000005];void getnext(){    int i=0,j=-1;    next[0]=-1;    while(i!=lenp)    {        if(j==-1||p[i]==p[j])        {            next[++i]=++j;        }        else        {            j=next[j];        }    }}int KMP(){    int i=0,j=0,c=0;    while(i!=lent&&j!=lenp)    {        if(t[i]==p[j]||j==-1)        {            ++i,++j;        }        else        {            j=next[j];        }        if(j==lenp)        {            c++;            j=next[j];        }    }    return c;}int main(){    int n,i,k,j,ans;    scanf("%d",&n);    getchar();    while(n--)    {        scanf("%s%s",p,t);        lent=strlen(t);        lenp=strlen(p);        getnext();        ans=KMP();        printf("%d/n",ans);    }    return 0;}
上一篇:skudo數獨問題

下一篇:SnakeGame

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 渝中区| 城市| 富顺县| 嫩江县| 红河县| 龙岩市| 和田市| 武夷山市| 兰西县| 秦皇岛市| 五华县| 中山市| 罗平县| 师宗县| 乐清市| 芮城县| 从江县| 秭归县| 瑞安市| 永川市| 政和县| 漾濞| 永康市| 北碚区| 旬邑县| 大厂| 宜兰市| 当阳市| 兴国县| 永济市| 太仓市| 武川县| 阿合奇县| 阿坝县| 孟津县| 灌云县| 灌云县| 大安市| 建昌县| 汝南县| 衡阳县|