题目

分析

对于当前枚举串 \(now\),从前往后扫。若扫到 \(i\),\(s_i\) 是 ; \(s_j\) 的子串 \((i < j < now)\),我们就可以跳过不匹配 \(i\)。因为如果\(s_i\)是\(s_j\) 的子串,那么\(s_j\)如果是\(s_now\)的子串,其实就不需要比较\(s_i\)和\(s_now\)。若不存在这样的 \(j\),匹配即可,若 \(s_i\)是 \(snow\) 的子串,\(i\) 之后就可以跳过了 (打个标记,或者用双向链表);否则 \(now\) 就可以更新答案,然后break。

#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
const int maxlongint=2147483647;
const int mo=1000000007;
const int N=505;
using namespace std;
char s[N][N*4];
int next[N*4],t,n,ans,bz[N],len[N];
bool kmp(int x,int y)
{
long long j=0;
memset(next,0,sizeof(next));
for(long long i=2;i<=len[y];i++)
{
while(j && s[y][i]!=s[y][j+1]) j=next[j];
if(s[y][j+1]==s[y][i]) j++;
next[i]=j;
}
j=0;
for(long long i=1;i<=len[x];i++)
{
while(j && s[x][i]!=s[y][j+1]) j=next[j];
if(s[y][j+1]==s[x][i]) j++;
if(j==len[y]) return true;
}
return false;
}
int main()
{
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%s",s[i]+1);
len[i]=strlen(s[i]+1);
}
ans=0;
memset(bz,true,sizeof(bz));
for(int i=2;i<=n;i++)
{
for(int j=1;j<=i-1;j++)
if(bz[j])
{
if(kmp(i,j)) bz[j]=false;
else
{
ans=i;
break;
}
}
}
if(!ans) cout<<-1<<endl;
else cout<<ans<<endl;
}
}

最新文章

  1. Excel Note
  2. IIS 7 中设置文件上传大小的方法
  3. 【WP 8.1开发】推送通知测试服务端程序
  4. 【Leetcode】【Hard】Merge k Sorted Lists
  5. 设计模式之美:Prototype(原型)
  6. Watchdog
  7. C#调用NPOI组件导出Excel表格
  8. 头部固定下面滑动&amp;&amp;获取手机屏高
  9. 如何在腾讯云上开发一款O2O书签?
  10. Swift计算文本宽高
  11. 记录一次MVC3升级MVC4遇到的问题
  12. [flex &amp; bison]编译器杂谈
  13. git生成密钥
  14. C# 使用PictureBox控件--点击切换图片
  15. 客房收费系统改造(三)—厂+反射+DAL
  16. MVC验证06-自定义错误信息
  17. C++ 11 学习3:显示虚函数重载(override)
  18. selenium+python环境的搭建的自动化测试
  19. sklearn中的损失函数
  20. Linux系统常见的压缩与打包命令

热门文章

  1. P2951 【[USACO09OPEN]捉迷藏Hide and Seek】
  2. screen重新连接会话
  3. 第五周总结&amp;实验&#183;
  4. JackRabbit的来源
  5. Go语言基本数据类型(四)
  6. 关于eclipse设置JRebel
  7. 【6.10校内test】 noip模拟
  8. Qt两个类通过信号槽通信
  9. mysql 导出 导入sql 文件
  10. day04-jQuery