思路: 对于每个子串,求出 母串中 所有该子串 的 开始和结束位置,保存在 mark数组中,求完所有子串后,对mark数组按 结束位置排序,然后 用后一个的结束位置 减去 前一个的 开始 位置 再 减去 1,记录最大值
比如 aaaqwer  1  aaa 那么 最长为 aaqwer

用strstr判断子串是否存在于母串中。

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int maxn = 1000005; struct MARK {
int begin, end;
bool operator <(const MARK& cmp) const {
return end < cmp.end;
}
} mark[maxn]; char s[maxn], t[1005][105];
int n, cnt, next[105]; void work(const char str[], const char sub[]) {
//memset(next, 0, sizeof(next));
//get_next(sub, next);
int exp = 0, from, len = strlen(sub);
while (strstr(str + exp, sub) != NULL) {
from = strstr(str + exp, sub) - str;
mark[cnt].begin = from;
mark[cnt].end = from + len - 1;
cnt++;
exp = from + len - 1;
}
} int main() {
while (scanf("%s", s) == 1) {
scanf("%d", &n);
for (int i = 0; i < n; i++)
scanf("%s", t[i]);
cnt = 0;
for (int i = 0; i < n; i++) {
work(s, t[i]);
}
mark[cnt].begin = mark[cnt].end = strlen(s);
cnt++;
sort(mark, mark + cnt);
int ans = -1;
for (int i = 0; i < cnt - 1; i++) {
int len = mark[i + 1].end - mark[i].begin - 1;
if (len > ans)
ans = len;
}
printf("%d\n", ans == -1 ? strlen(s) : ans);
}
}

用KMP判断子串是否存在于母串中。

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int maxn = 1000005; struct MARK {
int begin, end;
bool operator <(const MARK& cmp) const {
return end < cmp.end;
}
} mark[maxn]; char s[maxn], t[1005][105];
int n, cnt, next[105]; void get_next(const char *sub, int *next) {
int len = strlen(sub);
int i, k;
next[0] = k = -1;
for (i = 0; i < len;) {
if (k == -1 || sub[i] == sub[k]) {
k++;
i++;
if (sub[k] != sub[i])
next[i] = k;
else
next[i] = next[k];
} else
k = next[k];
}
} int KMP(const char *str, const char *sub, const int *next) {
int i, j;
int len1 = strlen(str), len2 = strlen(sub);
for (i = 0, j = 0; i < len1 && j < len2;) {
if (j == -1 || str[i] == sub[j]) {
i++;
j++;
} else
j = next[j];
}
if (j == len2)
return i - len2;
return -1;
} void work(const char str[], const char sub[]) {
//memset(next, 0, sizeof(next));
get_next(sub, next);
int exp = 0, from = 0, len = strlen(sub);
while ((from = KMP(str + exp, sub, next)) != -1) {
mark[cnt].begin = from + exp;
mark[cnt].end = from + exp + len - 1;
cnt++;
exp += from + len - (len == 1 ? 0 : 1);
}
} int main() {
while (scanf("%s", s) == 1) {
scanf("%d", &n);
for (int i = 0; i < n; i++)
scanf("%s", t[i]);
cnt = 0;
for (int i = 0; i < n; i++) {
work(s, t[i]);
}
// for (int i = 0; i < cnt; i++)
// printf("%d %d\n", mark[i].begin, mark[i].end);
mark[cnt].begin = mark[cnt].end = strlen(s);
cnt++;
sort(mark, mark + cnt);
int ans = -1;
for (int i = 0; i < cnt - 1; i++) {
int len = mark[i + 1].end - mark[i].begin - 1;
if (len > ans)
ans = len;
}
printf("%d\n", ans == -1 ? strlen(s) : ans);
}
}

福州大学第十届校赛 & fzu 2128最长子串的更多相关文章

  1. FZU 2128 最长子串

    题目链接:最长子串 思路:依次找出每个子串的在字符串中的首尾地址,所有子串先按照尾地址从小到大排序.然后首地址从小到大排. 遍历一遍每个子串的首地址和它后面相邻子串的尾地址之差-1, 第一个子串的首地 ...

  2. 河南省第十届省赛 Plumbing the depth of lake (模拟)

    title: Plumbing the depth of lake 河南省第十届省赛 题目描述: There is a mysterious lake in the north of Tibet. A ...

  3. 河南省第十届省赛 Intelligent Parking Building

    title: Intelligent Parking Building 河南省第十届省赛 tags: [模拟,省赛] 题目描述: There is a new revolution in the pa ...

  4. 四川第十届省赛 A.Angel Beats bitset

    四川第十届省赛 A.Angel Beats bitset 题目链接 题解参考:http://www.cnblogs.com/Aragaki/p/9142250.html 考虑用bitset来维护对于所 ...

  5. squee_spoon and his Cube VI---郑大校赛(求最长子串)

    市面上最常见的魔方,是三阶魔方,英文名为Rubik's Cube,以魔方的发明者鲁比克教授的名字命名.另外,二阶魔方叫Pocket Cube,它只有2*2*2个角块,通常也就比较小:四阶魔方叫Reve ...

  6. Problem 2128 最长子串(kmp+strstr好题经典)

     Problem 2128 最长子串 Accept: 134    Submit: 523Time Limit: 3000 mSec    Memory Limit : 65536 KB  Probl ...

  7. CSUST 第15届 校赛总结

    一直想记录一下自己的比赛,却感觉空间说说有点不适,思考了一番还是打算放到自己的博客园 这次比赛总体来说还是不错,签到还是稳的一批,基本前四小时都在rk1 开局切了几道签到题,然后开了一道思维gcd,正 ...

  8. HZNU第十二届校赛赛后补题

    愉快的校赛翻皮水! 题解 A 温暖的签到,注意用gets #include <map> #include <set> #include <ctime> #inclu ...

  9. fzu Problem 2128 最长子串(KMP + strstr 经典好题)

     Problem Description 问题很简单,给你一个字符串s,问s的子串中不包含s1,s2...sn的最长串有多长.  Input 输入包含多组数据.第一行为字符串s,字符串s的长度1到10 ...

随机推荐

  1. SimpleDateFormat使用具体解释

      public class SimpleDateFormat extends DateFormat SimpleDateFormat 是一个以国别敏感的方式格式化和分析数据的详细类. 它同意格式化 ...

  2. Ext.net中常用的三种交互方式

    http://www.ext.net.cn/forum.php?mod=viewthread&tid=10433

  3. 自己用js写的两个日历控件

    前一阵写了两个日历控件,做了简单的封装,发出来共朋友们参考. 第一个日历控件,条状的日历. (使用方法:调用initBarTime(id,evn),第一个参数是要渲染div的id,第二个参数是点击日期 ...

  4. 知识点1-4:ASP.NET MVC的好处

    ASP.NET MVC解决了ASP.NET Web Form的许多缺点.当在.NET平台上开发新的应用程序时,这使ASP.NET MVC成为一种更好的选择. 1. 对HTML的完全控制 2. 对URL ...

  5. win7系统远程连接其它计算机,并且向远程机传输文件

    首先,打开开始菜单,在程序自带的 “附件“ 中找到 "远程桌面连接"并打开,出现远程桌面对话框: 其次,在对话框左下角点击“选项”,选择“本地资源对话框”,在本地设备和资源下点击“ ...

  6. Oracle10g数据泵EXPDP和IMPDP备份与恢复数据

    Oracle10g数据泵EXPDP和IMPDP备份与恢复数据 一.数据库备份前准备工作 新建备份DIRECTORY目录,并授权给用户 步骤: 1.登录sqlplus 账户名:ptemp 密码:0000 ...

  7. 第14周 项目三-OOP版电子词典

    做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对比的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开. (1)编程序,由用户输入英文词.显示词性和中文释义. ...

  8. Android 富文本框实现 RichEditText

    Android系统自带控件没有富文本框控件,如果想写一封带格式的邮件基本上不可能,EdtiText只有默认一种格式,显示不能滿足要求,!!正好项目需要研究了一下,开发了此控件,现将一些源代码开放一下, ...

  9. Linux内核-系统调用

    Linux内核-系统调用 1.与内核通信 #系统调用在用户空间进程和硬件设备之间添加了一个中间层 作用:1.为用户空间提供了一种硬件的抽象接口 2.系统调用保证了系统的稳定和安全 3.出于每一个进程都 ...

  10. o(n)解决问题:调整数组顺序是奇数位于偶数的前面

    问题描述: 输入一个整数数组,调整数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分 void reOrder(int *a,int len) { if(a==NULL || ...