zoukankan      html  css  js  c++  java
  • HDU2087(KMP入门题)

    剪花布条

    Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 13382    Accepted Submission(s): 8538


    Problem Description
    一块花布条,里面有些图案,另有一块直接可用的小饰条,里面也有一些图案。对于给定的花布条和小饰条,计算一下能从花布条中尽可能剪出几块小饰条来呢?
     
    Input
    输入中含有一些数据,分别是成对出现的花布条和小饰条,其布条都是用可见ASCII字符表示的,可见的ASCII字符有多少个,布条的花纹也有多少种花样。花纹条和小饰条不会超过1000个字符长。如果遇见#字符,则不再进行工作。
     
    Output
    输出能从花纹布中剪出的最多小饰条个数,如果一块都没有,那就老老实实输出0,每个结果之间应换行。
     
    Sample Input
    abcde a3
    aaaaaa aa
    #
     
    Sample Output
    0
    3
    #include<cstdio>
    #include<cstring>
    using namespace std;
    char a[1005];
    char b[1005];
    int lena,lenb;
    int next[1005];
    void getnext()
    {
        int i=0,k=-1;
        next[0]=-1;
        while(i<lenb)
        {
            if(k==-1||b[i]==b[k])
            {
                i++;
                k++;
                next[i]=k;
            }
            else    k=next[k];
        }
    }
    int KMP()
    {
        getnext();
        int i=0,j=0;
        int cnt=0;
        while(i<lena)
        {
            if(j==-1||a[i]==b[j])
            {
                i++;
                j++;
            }
            else    j=next[j];
            if(j==lenb)
            {
                cnt++;
                j=0;//若两个不同的匹配没有交集则j=0,若存在交集则j=next[j]; 
            }
        }
        return cnt;
    }
    int main()
    {
        while(scanf("%s",a)!=EOF)
        {
            if(*a=='#')    break;
            scanf("%s",b);
            lena=strlen(a);
            lenb=strlen(b);    
            printf("%d
    ",KMP());
        }
       
        return 0;
    }
  • 相关阅读:
    poj 2312 Battle City
    poj 2002 Squares
    poj 3641 Pseudoprime numbers
    poj 3580 SuperMemo
    poj 3281 Dining
    poj 3259 Wormholes
    poj 3080 Blue Jeans
    poj 3070 Fibonacci
    poj 2887 Big String
    poj 2631 Roads in the North
  • 原文地址:https://www.cnblogs.com/program-ccc/p/5198913.html
Copyright © 2011-2022 走看看