国产探花免费观看_亚洲丰满少妇自慰呻吟_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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 麻江县| 柳河县| 桃园市| 泉州市| 渝中区| 吉林省| 安岳县| 江安县| 兰坪| 沅陵县| 康保县| 黄平县| 新安县| 鄂州市| 乐业县| 方城县| 木兰县| 海城市| 北川| 中宁县| 民县| 额敏县| 巍山| 永靖县| 建阳市| 弥渡县| 阜宁县| 肥城市| 福州市| 淮阳县| 平江县| 陇南市| 军事| 赫章县| 平潭县| 福贡县| 田东县| 淳化县| 甘肃省| 滦南县| 无锡市|