A 旋转字符串

旋转字符串

S0...n−10...n−1是一个长度为n的字符串,定义旋转函数Left(S)=S1…n−11…n−1+S00.比如S=”abcd”,Left(S)=”bcda”.一个串是对串当且仅当这个串长度为偶数,前半段和后半段一样。比如”abcabc”是对串,”aabbcc”则不是。

现在问题是给定一个字符串,判断他是否可以由一个对串旋转任意次得到。

Input

第1行:给出一个字符串(字符串非空串,只包含小写字母,长度不超过1000000)

Output

对于每个测试用例,输出结果占一行,如果能,输出YES,否则输出NO。

Sample Input

aa
ab

Sample Output

YES
NO

这道题首先给了一个旋转函数,但是注意思考会发现,这个旋转函数对于我们解题啥用都没有。就进行一个简单的判断即可

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
    char a[1000010];
    int i,len,t;
    while(~scanf("%s",a))
    {
        int sum;
        t=0;
        len=strlen(a);
        sum=(len+1)/2;
        for(i=0;i<sum;i++)
        {
            if(a[i]!=a[sum+i])
            {
                t=1;
                break;
            }
        }
        if(t==0) printf("YES\n");
        else printf("NO\n");
    }
}

猜你喜欢

转载自blog.csdn.net/rangran/article/details/81709676