• 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;
    }
  • 相关阅读:
    用了这款docker监控平台,再也不用记一大堆命令了,真香!
    自动化脚本如何切换环境?Pytest这些功能你必须要掌握
    5年高级测试员,还不会用Pytest+Allure实现自动化用例失败截图
    guava包Range操作
    guava包EventBus
    guava集合类(一)
    Neo4j基本入门
    在springboot中使用jdbcTemplate(6)
    guava包Strings工具类
    ASM介绍及简易教程(转)
  • 原文地址:https://www.cnblogs.com/program-ccc/p/5199324.html
Copyright © 2020-2023  润新知