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

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

Oulipo POJ - 3461

2019-11-14 10:40:55
字體:
來源:轉載
供稿:網友

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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 庆元县| 霍邱县| 镇宁| 新丰县| 古交市| 峡江县| 壤塘县| 会泽县| 陇西县| 巴东县| 诸城市| 平顶山市| 金华市| 本溪| 建湖县| 锦屏县| 五台县| 滨海县| 鄂尔多斯市| 临清市| 扶余县| 汉沽区| 滦平县| 洪洞县| 额济纳旗| 东海县| 高雄市| 丁青县| 新化县| 喜德县| 赫章县| 正宁县| 汉阴县| 江孜县| 凤台县| 高尔夫| 诸暨市| 诸暨市| 永丰县| 苗栗市| 浦江县|