暑期个人赛--第九场--C(字符串 朴素查找)
2014-08-08 10:14
120 查看
477. 新来的小妹妹
时间限制 6000 ms 内存限制 65536KB
题目描述
Mays王国的女王大人每天过着自由自在的生活,她最大的乐趣就是给邻国的帅气王子写信。而负责给她送信的就是皇家小妹妹快递公司。今天负责给女王大人送信的是一个新来的小妹妹,她非常好奇女王大人的信,于是悄悄的把它拆开来看了!但是机智的女王大人早就想到了会有这种情况发生,她和邻国帅气王子的信都是加密过的~
小妹妹研究了一路,她感觉,里面重复比较多的内容应该是有用信息。为了安慰自己的智商,小妹妹希望找到信的一个最长连续的子串,这个子串出现2次或以上。为了能找到的子串尽可能长,小妹妹认为即便出现的2次有一部分重叠也是可以的。
输入格式
输入第一行为数据组数T(T<=10),每组一行字符串str,str中只包含小写字母,且长度不超过2000。
输出格式
每组答案输出一行。
输入样例
2 aabbaabbaa abcde
输出样例
6 0
赛中提交:TT
赛后AC:Y
题目大意:
给一个字符串,找出一个“最长的在母串中存在相同串的子串”
思路与反省:
这次使用了朴素查找的算法,再加上一个小优化
即i和j的循环先遍历两个串的起点,i从0开始,j从i+1开始
第三层循环再用k去遍两个串的长度
小优化是”当当前找到的子串最大长度已经大于当前循环可能达到的最大长度后“就终止循环
用了朴素还是T了的原因就是只在i的循环中加了优化,而没有在j中加优化
后来加了就过了
赛中用字典树提交了一次T,
然后用朴素算法提交了一次T。
赛后重新写了一遍朴素算法提交了一次T,
然后改了一个小细节就就AC了。
下面是ac代码:
#include <iostream> #include <string.h> #include <stdio.h> #include <stdlib.h> #include <math.h> #include <string> #include <vector> #include <list> #include <map> #include <queue> #include <stack> #include <bitset> #include <algorithm> #include <numeric> #include <functional> #define maxn 500005 using namespace std; int main() { int T; scanf("%d",&T); while(T--){ char str[2005]={'\0'}; getchar(); scanf("%s",str); int maxlen=0; int length=strlen(str); //printf("length is:%d\n",length); for(int i=0;length-i-1>=maxlen;i+=1){ //printf("(%d %c)\n",i,str[i]); for(int j=i+1;length-j-1>=maxlen;j+=1){ if(str[j]==str[i]){ int len=1; for(int k=1;j+k<length;k+=1){ if(str[j+k]!=str[i+k]){ break; } len+=1; } maxlen=max(maxlen,len); } } } printf("%d\n",maxlen); } return 0; }
相关文章推荐
- 暑期个人赛--第九场--A
- 朴素匹配算法-子字符串的查找
- 字符串查找strstr个人实现
- (待切,标记上)暑期个人赛--第九场--E
- 字符串查找——朴素查找和kmp算法
- 暑期个人赛--第十一场--B(字符串哈希 Karp-Rabin)
- (待切,标记上)暑期个人赛--第九场--B
- 字符串的查找:朴素查找算法和KMP算法
- 从字符串中查找字符出现次数的方法和性能对比
- 在字符串中查找子字符串的算法
- 在当前数据库的所有表,所有字段查找字符串
- 用Boost来查找过滤字符串
- ASP.NET正则表达式查找字符串中重复的字符
- 从字符串中查找字符出现次数的方法和性能再比
- 从字符串字段中,查找全是数字的记录
- oracle中常用的字符串查找、替换以及截取函数的用法!
- 在字符串中查找最长重复子串的探讨
- 1个人开发操作系统之数组与字符串的使用
- 下面这个存储过程用来在某个数据库中的所有表中查找某一字符串
- 在一个长字符串中查找"包含所要求多个字符串的最短字符串"的VBscript算法