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

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

Oulipo POJ - 3461

2019-11-14 12:03:44
字體:
來源:轉載
供稿:網友

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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 县级市| 邳州市| 天水市| 白银市| 五河县| 水富县| 中江县| 建瓯市| 贵定县| 谷城县| 习水县| 安平县| 建水县| 渑池县| 楚雄市| 方城县| 唐河县| 东丽区| 湘西| 北海市| 镇平县| 且末县| 莱州市| 建阳市| 武穴市| 日土县| 都昌县| 叙永县| 白城市| 乌兰浩特市| 新竹县| 女性| 陵川县| 禄劝| 西昌市| 雅江县| 锦屏县| 太仓市| 汤阴县| 仙居县| 阳西县|