Blue Jeans---poj3080(kmp+暴力求子串)
题目链接:http://poj.org/problem?id=3080
题意就是求n个长度为60的串中求最长公共子序列(长度>=3);如果有多个输出字典序最小的;
我们可以暴力求出第一个串的所有子串,然后判断是否是其他的子串即可;
#include<iostream>
#include<stdio.h>
#include<string.h>
using namespace std; const int N = ;
char s[N][];
int Next[N]; void GetNext(char a[], int n)
{
int i=,j=-;
Next[]=-;
while(i<n)
{
if(j==- || a[i]==a[j])
Next[++i] = ++j;
else
j=Next[j];
}
} int kmp(char a[], char b[], int n)
{
int i=, j=;
while(i<)
{ if(j==- || b[i] == a[j])
i++, j++;
else
j = Next[j];
if(j==n)
return true;
}
return false;
} int main()
{
int T, n,f;
scanf("%d", &T);
while(T--)
{
char ans[N]="Z";
scanf("%d", &n);
for(int i=; i<n; i++)
scanf("%s", s[i]);
for(int len=; len>=; len--)///子串的长度;
{
for(int i=; i<=-len; i++)///子串的开始下标;
{
char subStr[N]= {};
strncpy(subStr, s[]+i, len); GetNext(subStr, len);///从subStr中得到Next;
int flag = ;
for(int j=; j<n; j++)
{
if(!kmp(subStr, s[j], len))
{
flag=;
break;
}
}
if(flag == && strcmp(ans, subStr)>)
strcpy(ans, subStr);
}
f=;
if(ans[]!='Z')
{
printf("%s\n", ans);
f=;
break;
}
}
if(f==)
printf("no significant commonalities\n"); }
return ;
}
Blue Jeans---poj3080(kmp+暴力求子串)的更多相关文章
- POJ - 3080 Blue Jeans 【KMP+暴力】(最大公共字串)
<题目链接> 题目大意: 就是求k个长度为60的字符串的最长连续公共子串,2<=k<=10 限制条件: 1. 最长公共串长度小于3输出 no significant co ...
- poj3080 Blue Jeans【KMP】【暴力】
Blue Jeans Time Limit: 1000MS Memory Limit: 65536K Total Submissions:21746 Accepted: 9653 Descri ...
- POJ 3080 Blue Jeans 找最长公共子串(暴力模拟+KMP匹配)
Blue Jeans Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 20966 Accepted: 9279 Descr ...
- POJ Blue Jeans [枚举+KMP]
传送门 F - Blue Jeans Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u ...
- POJ 3080 Blue Jeans (字符串处理暴力枚举)
Blue Jeans Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 21078 Accepted: ...
- Blue Jeans[poj3080]题解
题目 Description - The Genographic Project is a research partnership between IBM and The National Geog ...
- POJ3080 Blue Jeans 题解 KMP算法
题目链接:http://poj.org/problem?id=3080 题目大意:给你N个长度为60的字符串(N<=10),求他们的最长公共子串(长度>=3). 题目分析:KMP字符串匹配 ...
- POJ 3080 Blue Jeans (KMP)
求出公共子序列 要求最长 字典序最小 枚举第一串的所有子串 然后对每一个串做KMP.找到目标子串 学会了 strncpy函数的使用 我已可入灵魂 #include <iostre ...
- poj-3080(kmp+暴力枚举)
题意:给你多个字符串,问你这几个字符串的最长公共子串是哪个,如果有多个,输出字典序最大的那个,如果最长的公共子串长度小于3,输出一个奇怪的东西: 解题思路:首先看数据,数据不大,开始简单快乐的暴力之路 ...
随机推荐
- tableview 与 tableview cell
1.tableview cell: import Foundationimport UIKit class CjwtCell: UITableViewCell { @IBOutlet var lb_c ...
- 基于 jQuery支持移动触摸设备的Lightbox插件
Swipebox是一款支持桌面.移动触摸手机和平板电脑的jquery Lightbox插件.该lightbox插件支持手机的触摸手势,支持桌面电脑的键盘导航,并且支持视频的播放. 在线预览 源码下 ...
- android版本号始终为1
之前用Eclipse里时,版本号是检查是做如下 <manifest xmlns:android="http://schemas.android.com/apk/res/android& ...
- Codeforces461A Appleman and Toastman 贪心
题目大意是Appleman每次将Toastman给他的Ni个数拆分成两部分后再还给Toastman,若Ni == 1则直接丢弃不拆分.而Toastman将每次获得的Mi个数累加起来作为分数,初始时To ...
- Android——初学
- SSL/TLS协议运行机制的概述_转
转自:SSL/TLS协议运行机制的概述 作者: 阮一峰 日期: 2014年2月 5日 互联网的通信安全,建立在SSL/TLS协议之上. 本文简要介绍SSL/TLS协议的运行机制.文章的重点是设计思想和 ...
- EasyUI 异步Tree
用etmvc framework返回json数据.创建HTML标记 <ul id="tt"></ul> 创建jQuery代码我们使用url属性来指向远程数据 ...
- tf.nn.conv2d实现卷积的过程
#coding=utf-8 import tensorflow as tf #case 2 input = tf.Variable(tf.round(10 * tf.random_normal([1, ...
- xsocket:空闲超时问题。
XSocket是什么? java的nio的封装. 详情: 1. http://xsocket.sourceforge.net/core/apidocs/2_1/index.html 2. http:/ ...
- TCP通信服务端及客户端代码
Java TCP通信使用的是Socket(客服端)和ServerSocket(服务端),具体代码如下. server端代码: import java.io.BufferedReader; import ...