题目描述
判断亲和串。亲和串的定义是这样的:给定两个字符串s1和s2,如果能通过s1循环移位,使s2包含在s1中,那么我们就说s2 是s1的亲和串。
输入
本题有多组测试数据,每组数据的第一行包含输入字符串s1,第二行包含输入字符串s2,s1与s2的长度均小于100000。
输出
如果s2是s1的亲和串,则输出"yes",反之,输出"no"。每组测试的输出占一行。
样例
输入
AABCD
CDAA
ASD
ASDF
ab
aba
输出
yes
no
no
思路
因为s2 可能是s1 循环改变顺序得到的,所以直接把s1复制一次,来判断
代码
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define M 200000+5
#define MS(a, b) memset(a, b, sizeof(a))
char s1[M], s2[M], s[M];
int main() {
while (~scanf("%s%s", s1, s2)) {
int len1 = strlen(s1);
int len2 = strlen(s2);
if (len1 < len2) {
printf("no\n");
continue;
}
strcpy(s, s1);
strcat(s1, s);
if (strstr(s1, s2) != NULL) {
printf("yes\n");
}
else printf("no\n");
}
return 0;
}