Description

今天来写作文啦!
非常善于堆砌辞藻。在洋洋洒洒写了一长篇之后,小发现作文中很多段落都似曾相识。小认为,如果一段字符在文章开头,结尾和中间都出现过,那么这段字符就可以被认为是一个“经典段”。
现在小给你一篇文章,他想知道最长的一段“经典段”长度是多少?
注意,这里要求经典串至少出现三次,分别作为文章的前缀,后缀,及既非前缀也非后缀。

Input

一行,给出一个由小写字母组成的字符串。

Output

输出满足题目要求的非空子串,如果不存在这样的非空子串输出。(字符串严格匹配,不含双引号)

Sample Input

fixprefixsuffix

Sample Output

fix

HINT

字符串长度

Solution

预处理出这个字符串能与后缀匹配的前缀最长子串.

数组求出中哪些下标使得后缀.

匹配,求出最大的使得后缀.

  1. #include<cmath>
  2. #include<ctime>
  3. #include<stack>
  4. #include<queue>
  5. #include<cstdio>
  6. #include<vector>
  7. #include<cstring>
  8. #include<cstdlib>
  9. #include<iostream>
  10. #include<algorithm>
  11. #define N 1000005
  12. using namespace std;
  13. int nxt[N],n,ans;
  14. bool f[N];
  15. char a[N],b[N],c[N];
  16. inline void get_nxt(char b[],int n){
  17. for(int i=2,j=0;i<=n;++i){
  18. while(j&&b[j+1]!=b[i]) j=nxt[j];
  19. if(b[j+1]==b[i]) ++j;
  20. nxt[i]=j;
  21. }
  22. }
  23. inline void kmp1(){
  24. int k=0;
  25. for(int i=1,j=0;i<n;++i){
  26. while(j&&b[j+1]!=a[i]) j=nxt[j];
  27. if(b[j+1]==a[i]) ++j;
  28. if(i==n-1) k=j;
  29. }
  30. while(k){
  31. //printf("k=%d\n",k);
  32. f[k]=true;k=nxt[k];
  33. }
  34. }
  35. inline int kmp2(){
  36. int ret=0;get_nxt(a,n);
  37. for(int i=2,j=0;i<n;++i){
  38. while(j&&c[j+1]!=c[i]) j=nxt[j];
  39. if(c[j+1]==c[i])
  40. if(f[++j]) ret=max(ret,j);
  41. }
  42. return ret;
  43. }
  44. inline void print(){
  45. printf("Y can't find any classical string.\n");
  46. }
  47. inline void init(){
  48. scanf("%s",c+1);n=strlen(c+1);
  49. if(n<3){
  50. print();return;
  51. }
  52. for(int i=n,j=1;i>1;--i,++j)
  53. b[j]=c[i];
  54. for(int i=n-1,j=1;i;--i,++j)
  55. a[j]=c[i];
  56. get_nxt(b,n-1);kmp1();
  57. ans=kmp2();
  58. if(ans){
  59. for(int i=ans;i;--i)
  60. printf("%c",b[i]);
  61. printf("\n");
  62. }
  63. else print();
  64. }
  65. int main(){
  66. freopen("article.in","r",stdin);
  67. freopen("article.out","w",stdout);
  68. init();
  69. fclose(stdin);
  70. fclose(stdout);
  71. return 0;
  72. }

[日常训练]article的更多相关文章

  1. 「日常训练」ZgukistringZ(Codeforces Round #307 Div. 2 B)

    题意与分析(CodeForces 551B) 这他妈哪里是日常训练,这是日常弟中弟. 题意是这样的,给出一个字符串A,再给出两个字符串B,C,求A中任意量字符交换后(不限制次数)能够得到的使B,C作为 ...

  2. 「日常训练」 Fire!(UVA-11624)

    与其说是训练不如说是重温.重新写了Java版本的代码. import java.util.*; import java.math.*; import java.io.BufferedInputStre ...

  3. 「日常训练」Known Notation(ZOJ-3829)

    题意与分析 题意是这样的:给一个字符串,字符串中只包含数字和运算符'*'.现在问字符串是不是一个合法的逆波兰式(后缀表达式).已知逆波兰式的空格消除,也就是说123可以看成123也可以看成1和23.如 ...

  4. 「日常训练」 Genghis Khan the Conqueror(HDU-4126)

    题意 给定\(n\)个点和\(m\)条无向边(\(n\le 3000\)),需要将这\(n\)个点连通.但是有\(Q\)次(\(Q\le 10^4\))等概率的破坏,每次破坏会把\(m\)条边中的某条 ...

  5. 「日常训练&知识学习」单调栈

    这几天的知识学习比较多,因为时间不够了.加油吧,为了梦想. 这里写几条简单的单调栈作为题解记录,因为单调栈的用法很简单,可是想到并转化成用这个需要一些题目的积淀. 相关博客参见:https://blo ...

  6. 「日常训练&知识学习」莫队算法(二):树上莫队(Count on a tree II,SPOJ COT2)

    题意与分析 题意是这样的,给定一颗节点有权值的树,然后给若干个询问,每次询问让你找出一条链上有多少个不同权值. 写这题之前要参看我的三个blog:Codeforces Round #326 Div. ...

  7. 「日常训练&知识学习」树的分块(王室联邦,HYSBZ-1086)

    题意与分析 这题的题意就是树分块,更具体的看题目(中文题). 学习这一题是为了树的分块,为树上莫队做铺垫. 参考1:https://blog.csdn.net/LJH_KOQI/article/det ...

  8. 「知识学习&日常训练」莫队算法(一)(Codeforce Round #340 Div.2 E)

    题意 (CodeForces 617E) 已知一个长度为\(n\)的整数数列\(a[1],a[2],-,a[n]\),给定查询参数\(l,r\),问\([l,r]\)内,有多少连续子段满足异或和等于\ ...

  9. 「日常训练&知识学习」树的直径(POJ-1849,Two)

    题意 一个城市由节点和连接节点的街道组成,街道是双向的. 此刻大雪覆盖了这个城市,市长确定了一些街道要将它们清扫干净,这些街道保证所有的节点可以通过它们连通而且街道数目尽可能小. 现有两台相同的扫雪机 ...

随机推荐

  1. Mysql连接错误:Lost connection to Mysql server at 'waiting for initial communication packet'

    在远程连接mysql的时候,连接不上,出现如下报错:Lost connection to MySQL server at 'waiting for initial communication pack ...

  2. linux负载均衡总结性说明(四层负载/七层负载)

    在常规运维工作中,经常会运用到负载均衡服务.负载均衡分为四层负载和七层负载,那么这两者之间有什么不同?废话不多说,详解如下: 一,什么是负载均衡1)负载均衡(Load Balance)建立在现有网络结 ...

  3. [Cache] C#操作缓存--CacheHelper缓存帮助类 [复制链接]

    using System;using System.Web;using System.Collections; namespace DotNet.Utilities{ public class Cac ...

  4. DPABI advanced edition 文件夹组织形式

    ❤ Regress out nuisance: ... csf\wm ('SPM apriori') {working directory}\Masks\WarpedMasks\SubIndex_Wh ...

  5. 在Azure上搭建Orchard CRM入口网站

    这是英文版:Setup Orchard CRM portal website on Azure

  6. intellij idea 高级用法之:集成JIRA、UML类图插件、集成SSH、集成FTP、Database管理

    之前写过一篇IntelliJ IDEA 13试用手记,idea还有很多高大上的功能,易用性几乎能与vs.net媲美,反正我自从改用idea后,再也没开过eclipse,今天来看几个高级功能: 一.与J ...

  7. 在线音乐网站【03】Part one 功能实现

    今天打算把网站功能的具体实现给总结一下,如果你想了解整个小项目,建议你先看看前面2篇博客. 1.在线音乐网站(1)需求和功能结构 2.在线音乐网站(2)数据库和开发环境 7.网站主要模块实现 a.在线 ...

  8. Nginx文件类型错误解析漏洞--攻击演练

    今天看书看到其中提到的一个漏洞,那就是Nginx+PHP的服务器中,如果PHP的配置里 cgi.fix_pathinfo=1 那么就会产生一个漏洞.这个配置默认是1的,设为0会导致很多MVC框架(如T ...

  9. grootjs 简明教程

    grootJs简明教程 mvvm框架也是解决的一类问题,在某些时候会提高生产效率: 经过接近一个月的努力,grootJs测试版终于发布了 grootJs是一个mvvm的框架,名字取 grass 和ro ...

  10. Python 处理数据库返回结果

    游标执行后返回的结果都只是数据,但是不带有列名标识.这里需要处理2个问题: 将返回的数据映射到每一列上 当返回的结果很大的时候,需要使用迭代器来提升性能. 解决上面的2个问题,在python里面可以采 ...