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

    亲和串

    Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 10862    Accepted Submission(s): 4940


    Problem Description
    人随着岁数的增长是越大越聪明还是越大越笨,这是一个值得全世界科学家思考的问题,同样的问题Eddy也一直在思考,因为他在很小的时候就知道亲和串如何判断了,但是发现,现在长大了却不知道怎么去判断亲和串了,于是他只好又再一次来请教聪明且乐于助人的你来解决这个问题。
    亲和串的定义是这样的:给定两个字符串s1和s2,如果能通过s1循环移位,使s2包含在s1中,那么我们就说s2 是s1的亲和串。
     
    Input
    本题有多组测试数据,每组数据的第一行包含输入字符串s1,第二行包含输入字符串s2,s1与s2的长度均小于100000。
     
    Output
    如果s2是s1的亲和串,则输出"yes",反之,输出"no"。每组测试的输出占一行。
     
    Sample Input
    AABCD
    CDAA
    ASD
    ASDF
     
    Sample Output
    yes
    no
    #include<cstdio>
    #include<cstring>
    using namespace std;
    char a[200005];
    char b[100005];
    int lena,lenb;
    int next[100005];
    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;
        while(i<lena)
        {
            if(j==-1||a[i]==b[j])
            {
                i++;
                j++;
            }
            else    j=next[j];
            if(j==lenb)    return i-j+1;
        }
        return -1;
    }
    int main()
    {
        while(scanf("%s%s",a,b)!=EOF)
        {
            lena=strlen(a);
            lenb=strlen(b);
            for(int i=lena;i<lena+lena;i++)
            {
                a[i]=a[i-lena];
            }
            lena+=lena;    
            if(KMP()!=-1)    printf("yes
    ");
            else    printf("no
    ");    
        }
       
        return 0;
    }
     利用C自带函数
    #include<cstdio>
    #include<cstring>
    using namespace std;
    char a[200005];
    char b[100005];
    char t[100005];
    int main()
    {
        while(scanf("%s%s",a,b)!=EOF)
        {
            strcpy(t,a);
            strcat(a,t);
            if(strstr(a,b)!=NULL)    printf("yes
    ");
            else    printf("no
    ");
        }
        return 0;
    }
  • 相关阅读:
    借助HTML分别禁用IE8, IE9的兼容视图模式的小技巧
    IE兼容性问题
    php解析html类库simple_html_dom
    jquery 自定义类
    JS:收集的一些Array及String原型对象的扩展实现代码
    JS 替换
    JQ 取窗口的宽度.窗口的框度历
    java判断时间是否在时间段内 开始时间大于结束时间返回true
    bootstrap4 nav 菜单
    CSS样式居中 -webkit-background-size:center;background-size:center;
  • 原文地址:https://www.cnblogs.com/program-ccc/p/5199324.html
Copyright © 2011-2022 走看看