题目链接:点击查看

题目大意:给出一个字符串 s ,求最长双回文子串,题目规定最长双回文子串 t 可以拆成左右两部分,满足两部分都是回文串

题目分析:一开始读错题了,以为是双回文串本身也需要是回文串,结果发现并不是,这样的话直接用回文自动机求就好了,其中有个参数len数组正好代表了以某个点为结尾的最长回文后缀的长度,正着跑一遍维护一个最长回文后缀的长度,然后再倒着跑一遍维护答案就好了

代码:

#include<iostream>
#include<cstdio>
#include<string>
#include<ctime>
#include<cmath>
#include<cstring>
#include<algorithm>
#include<stack>
#include<queue>
#include<map>
#include<set>
#include<sstream>
using namespace std;typedef long long LL;const int inf=0x3f3f3f3f;const int N=1e5+100;char s[N];int suf[N];struct Palindrome_tree
{int nxt[N][26];int fail[N]; // 当前节点最长回文后缀的节点int len[N]; // 当前节点表示的回文串的长度int cnt[N]; // 当前节点回文串的个数, 在getcnt后可得到全部int sed[N]; // 以当前节点为后缀的回文串的个数(并不是表示第i结尾的回文串的种类数,如果要求每个点结尾的数的回文串个数,得用last)int record[N]; //record记录了节点回文串的结束位置char s[N];int tot; // 节点个数int last; // 上一个节点int n;//当前字符串的长度 void init(){tot = n = 0;memset(fail, 0, sizeof fail);memset(cnt, 0, sizeof cnt);memset(sed, 0, sizeof sed);memset(len, 0, sizeof len);memset(nxt, 0, sizeof nxt);}void build(){len[0] = 0, len[1] = -1; // 0为偶数长度根, 1为奇数长度根tot = 1, last = 0;fail[0] = 1;}int getfail(int x, int n){while (s[n - len[x] - 1] != s[n]||n-len[x]-1<0) // 比较x节点回文串新建两端是否相等//n-len[x]-1<0这个是我自己加的,多组的时候光第一个条件是不够的,所以有错请手动删除x = fail[x]; // 若不同, 再比较x后缀回文串两端return x;}void insert(char ch){int c = ch - 'a';//全小写要用a 全大写要用A 不然会错s[++n]=ch;int p = getfail(last, n);// 得到第i个字符可以加到哪个节点的两端形成回文串if (!nxt[p][c]){tot++;len[tot] = len[p] + 2;  // 在p节点两端添加两个字符fail[tot] = nxt[getfail(fail[p], n)][c]; //tot点的后缀回文,可以由上一个节点的后缀回文尝试得到sed[tot] = sed[fail[tot]] + 1; // 以当前节点为结尾的回文串个数nxt[p][c] = tot; // 新建节点}last = nxt[p][c]; // 当前节点成为上一个节点cnt[last]++; //当前节点回文串++record[last] = n;}void get_cnt(){for (int i = tot; i > 0; i--)cnt[fail[i]] += cnt[i];//fail[i] 的节点 为 i 节点的后缀回文串, 所以个数相加}
}tree;int main()
{
//  freopen("input.txt","r",stdin);
//  ios::sync_with_stdio(false);scanf("%s",s);int n=strlen(s);tree.init();tree.build();for(int i=0;i<n;i++){tree.insert(s[i]);suf[i]=tree.len[tree.last];}tree.init();tree.build();int ans=0;for(int i=n-1;i>=1;i--){tree.insert(s[i]);ans=max(ans,suf[i-1]+tree.len[tree.last]);}printf("%d\n",ans);return 0;
}

HYSBZ - 2565 最长双回文串(回文自动机)相关推荐

  1. HYSBZ 2565 最长双回文串 (回文树)

    2565: 最长双回文串 Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 1377  Solved: 714 [Submit][Status][Dis ...

  2. HYSBZ 2565 最长双回文串

    题意:找到一个最长回文子串,该子串能够分成两长度大于0的部分,每部分都是一个回文串 题解:回文树维护一个以i为起点和终点的最长回文串长度数组即可 #include<bits/stdc++.h&g ...

  3. bzoj 2565: 最长双回文串 manacher算法

    2565: 最长双回文串 Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/problem. ...

  4. BZOJ 2565: 最长双回文串

    2565: 最长双回文串 Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 1769  Solved: 895 [Submit][Status][Dis ...

  5. 2565: 最长双回文串

    Description 顺序和逆序读起来完全一样的串叫做回文串.比如acbca是回文串,而abc不是(abc的顺序为"abc",逆序为"cba",不相同). 输 ...

  6. BZOJ 2565 最长双回文串 Manacher

    题目大意: 定义双回文串G是指一个可以被拆分成两个部分(S和T)的字符串G = S + T, 且S和T都是回文串的串, G自己本身可以不是回文串 给出一个长度为n ( 2 <= n <= ...

  7. HYSBZ - 3676 回文串(回文自动机)

    题目链接:点击查看 题目大意:求出回文子串中 出现次数*长度 的最大值 题目分析:回文自动机直接搞维护最大值就是答案了 代码: #include<iostream> #include< ...

  8. 论如何优雅的处理回文串 - 回文自动机详解

    写在前面 最近无意中看到了这个数据结构,顺便也就学习了一下. 而且发现网上关于这个算法的描述有很多地方是错的,在这里做了一些更正. 处理字符串的算法很多: KMP,E-KMP,AC自动机,后缀三兄弟: ...

  9. 2018.12.15 bzoj3676: [Apio2014]回文串(后缀自动机)

    传送门 对原串建立一个后缀自动机,然后用反串在上面匹配. 如果当前匹配的区间[l,r][l,r][l,r]包裹了当前状态的endposendposendpos中的最大值,那么[l,maxpos][l, ...

最新文章

  1. 代码执行流水之循环展开优化
  2. 编译py-faster-rcnn的问题汇总及解决方法
  3. 局部配置和全局配置_06. 教你零基础搭建小程序(解读全局配置文件-tabBar字段)...
  4. VC/MFC 键盘钩子,代码片断
  5. 小技巧 ----- 关于Java中的System.arraycopy()
  6. Nginx反向代理导致PHP获取不到正确的HTTP_HOST,SERVER_NAME,客户端IP的解决方法
  7. python的property用法_Python的@property使用方法详解
  8. 静态的顺序表(C语言实现)
  9. IP-guard功能模块简介
  10. 数字图像处理-高反差保留算法
  11. 《炬丰科技-半导体工艺》MEMS 应用中不同厚光刻胶的比较研究
  12. 浙大图灵班今年首次招生:院士授课,本科生配学业导师
  13. 安卓模拟器登录微信自动化测试最佳实践
  14. Sqoop export columns 参数使用
  15. JavaWeb开发 —— HTML
  16. IP地址欺骗 IP Spoof
  17. chrome 多窗口 android,谷歌提前放出安卓7.0开发者预览版:多窗口+画中画
  18. 批处理之ren命令-可批量修改文件名
  19. 关于广义莫比乌斯反演的思考
  20. 简单几步实现网络音乐播放器(Python爬虫版百度FM)

热门文章

  1. 通过Nginx复杂安装
  2. @EnableAutoConfiguration注解的实现原理
  3. 字节输入流一次读取多个字节
  4. MySQL复制性能优化
  5. php自定义框架,「php 框架」自定义php框架(篇一) - seo实验室
  6. 从键盘输入一个正整数(不多于5位),计算该正整数与789之和(记为sum)
  7. activiti 工作流 动态 设置 指定 节点任务人、责任人、组 的实现方式
  8. Java 开源库精选(持续更新)
  9. 纯css制作带三角(兼容所有浏览器)
  10. 【文文殿下】网络流学习笔记