(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的亲和串。
亲和串的定义是这样的:给定两个字符串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
- (KMP 1.6)hdu 2203 亲和串(判断文本串循环移位之后是否能将模式串包含在其中)
- HDU 2203 亲和串(KMP:循环移位)
- KMP hdu-2203-亲和串
- HDU 2203 亲和串 KMP
- hdu 2203 亲和串 kmp
- hdu 2203 亲和串(KMP)
- 亲和串 - HDU 2203 KMP
- 【HDU】2203 亲和串 KMP
- HDU 2203(KMP) 亲和串
- HDU 2203 亲和串 (KMP)
- hdu 2203 亲和串 KMP
- HDU - 2203 亲和串(Kmp)
- HDU 2203 亲和串 KMP
- HDU 2203 亲和串(简单KMP,不过需要预判断)
- hdu 2203 亲和串(KMP|strstr())
- HDU 2203 亲和串 KMP解法
- HDU 2203 亲和串(kmp)
- 亲和串 (hdu 2203 KMP)
- Struts2-注解配置 validations
- Google Code Jam 2015 Round 1A 解题报告
- 一个delete和析构函数引发的coredump
- Fedora20上源码安装Xen4.3.0
- leetcode:Roman to Integer
- (KMP 1.6)hdu 2203 亲和串(判断文本串循环移位之后是否能将模式串包含在其中)
- This text field does not specify an inputType or a hint
- 排序算法之交换排序(冒泡和快排)
- ESlint安装使用
- 把EXCEL用程序导入到ORACLE中(SpringMVC+MyBatis)
- 网页编码就是那点事
- 超级封装BaseAdapter,让你省下千万行代码
- Windows API实现窗口居中
- 自己成长路上