(KMP 1.6)hdu 2203 亲和串(判断文本串循环移位之后是否能将模式串包含在其中)

来源:互联网 发布:tk域名官方网站 编辑:程序博客网 时间:2024/06/06 05:50

题目:

亲和串

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


Problem Description
人随着岁数的增长是越大越聪明还是越大越笨,这是一个值得全世界科学家思考的问题,同样的问题Eddy也一直在思考,因为他在很小的时候就知道亲和串如何判断了,但是发现,现在长大了却不知道怎么去判断亲和串了,于是他只好又再一次来请教聪明且乐于助人的你来解决这个问题。
亲和串的定义是这样的:给定两个字符串s1和s2,如果能通过s1循环移位,使s2包含在s1中,那么我们就说s2 是s1的亲和串。
 

Input
本题有多组测试数据,每组数据的第一行包含输入字符串s1,第二行包含输入字符串s2,s1与s2的长度均小于100000。
 

Output
如果s2是s1的亲和串,则输出"yes",反之,输出"no"。每组测试的输出占一行。
 

Sample Input
AABCDCDAAASDASDF
 

Sample Output
yesno
 

Author
Eddy
 

Recommend
lcy   |   We have carefully selected several similar problems for you:  3336 2201 3068 2200 2206 


题目分析:

              KMP。简单题。


要使“s1循环移位”在后面再拼一个s1即可。



代码如下:

/* * hdu2206.cpp * *  Created on: 2015年4月18日 *      Author: Administrator */#include<iostream>#include<algorithm>#include<cstdio>#include<cstring>using namespace std;const int maxn = 100001;int n;//文本串的长度int m;//目标串的长度char text[maxn];//文本串char pattern[maxn];//模式串int nnext[maxn];//next数组.直接起next可能会跟系统中预定的重名/*O(m)的时间求next数组*/void get_next() {nnext[0] = nnext[1] = 0;for (int i = 1; i < m; i++) {int j = nnext[i];while (j && pattern[i] != pattern[j])j = nnext[j];nnext[i + 1] = pattern[i] == pattern[j] ? j + 1 : 0;}}/*o(n)的时间进行匹配 * * 返回第一次匹配的位置 */bool kmp() {bool flag = false;//用来标记是否能在文本串中找到模式串int j = 0;/*初始化在模式串的第一个位置*/for (int i = 0; i < n; i++) {/*遍历整个文本串*/while (j && pattern[j] != text[i])/*顺着失配边走,直到可以匹配,最坏得到情况是j = 0*/j = nnext[j];if (pattern[j] == text[i])/*如果匹配成功继续下一个位置*/j++;if (j == m) {/*如果找到了直接输出*/flag = true;}}return flag;}int main(){char tmp[maxn];while(scanf("%s%s",text,pattern)!=EOF){memcpy(tmp,text,sizeof(text));strcat(text,tmp);n = strlen(text);m = strlen(pattern);get_next();if(kmp() == true){printf("yes");}else{printf("no");}printf("\n");}return 0;}







1 0
原创粉丝点击