题目链接:点击查看

题目大意:求出回文子串中 出现次数*长度 的最大值

题目分析:回文自动机直接搞维护最大值就是答案了

代码:

#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=3e5+100;char s[N];int 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记录了节点回文串的结束位置int tot; // 节点个数int last; // 上一个节点void init(){tot = 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(char *s, 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* s, int n){for (int i = 0; i < n; i++){int c = s[i] - 'a';//全小写要用a 全大写要用A 不然会错int p = getfail(s, last, i);// 得到第i个字符可以加到哪个节点的两端形成回文串if (!nxt[p][c]){tot++;len[tot] = len[p] + 2;  // 在p节点两端添加两个字符fail[tot] = nxt[getfail(s, fail[p], i)][c]; //tot点的后缀回文,可以由上一个节点的后缀回文尝试得到sed[tot] = sed[fail[tot]] + 1; // 以当前节点为结尾的回文串个数nxt[p][c] = tot; // 新建节点}last = nxt[p][c]; // 当前节点成为上一个节点cnt[last]++; //当前节点回文串++record[last] = i;}}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);n=strlen(s);tree.init();tree.build();tree.insert(s,n);tree.get_cnt();LL ans=0;for(int i=1;i<=tree.tot;i++)ans=max(ans,1LL*tree.cnt[i]*tree.len[i]);printf("%lld\n",ans);return 0;
}

HYSBZ - 3676 回文串(回文自动机)相关推荐

  1. HYSBZ - 2565 最长双回文串(回文自动机)

    题目链接:点击查看 题目大意:给出一个字符串 s ,求最长双回文子串,题目规定最长双回文子串 t 可以拆成左右两部分,满足两部分都是回文串 题目分析:一开始读错题了,以为是双回文串本身也需要是回文串, ...

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

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

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

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

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

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

  5. 回文算法java实现_java算法题:最长回文串

    LeetCode: 给定一个包含大写字母和小写字母的字符串,找到通过这些字母构造成的最长的回文串.在构造过程中,请注意区分大小写.比如"Aa"不能当做一个回文字符串.注 意:假设字 ...

  6. 判断回文串,最长回文串方法

    1.判断回文串 回文串就是从左看与从右看都是一样的字符串,例如abcba,acddca 判断一个字符串是否为回文串:如判断s=abcdcba是否为回文串,只要看s以中间位分界线,s的左右两边是否相等即 ...

  7. APIO 2014 回文串(Manacher+后缀自动机+倍增)

    题意 https://www.lydsy.com/JudgeOnline/problem.php?id=3676 思路 好像还是回文自动机裸体,但是 \(\text{Manacher}\) +后缀自动 ...

  8. 【回文自动机】bzoj3676 [Apio2014]回文串

    回文自动机讲解!http://blog.csdn.net/u013368721/article/details/42100363 pam上每个点代表本质不同的回文子串.len(i)代表长度,cnt(i ...

  9. HYSBZ 2565 最长双回文串

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

最新文章

  1. usaco Fence Loops
  2. log_bin.index not found 启动报错解决
  3. 使用Movie Maker制作视频相册
  4. apache 编译支持php_apache2 不支持php文件 解决办法(示例代码)
  5. 基于nginx环境部署nagios
  6. Mac下配置svn服务器
  7. linux关机命令_Linux基于centOS 7.6常见的Linux命令
  8. 为什么同样是读书,有人能让自己的收益提高50倍,而你只能成为文艺的中年大叔?
  9. oracle如何规则显示,Oracle语句优化规则汇总
  10. matlab图片白边_Matlab论文插图消除白边的5种方法
  11. 向量距离计算 java_在机器学习中扮演着极为重要角色的向量
  12. NTFS文件系统详细分析
  13. 伪分布式Hbase安装和配置
  14. python股票交易模型_利用python建立股票量化交易系统(一)——小市值选股票模型...
  15. 互联网30年,总有人正年轻
  16. Container killed by YARN for exceeding memory limits
  17. 服务器c盘哪些文件可以删除吗,小编教你c盘里哪些文件可以删除
  18. 什么是jsp,什么是Servlet?jsp和Servlet有什么区别?
  19. LTE终端分类-LTE UE category
  20. 功率输出器件:直流电机工作原理

热门文章

  1. Spring构造注入重载
  2. Pod详解-资源配额
  3. RocketMQ中的Topic和JMS的queue有什么区别?
  4. 手写自己的MyBatis框架-Configuration
  5. response设置响应头
  6. 区域数据导入功能(在服务端接收上传文件)
  7. HDFS的API操作-获取文件列表信息
  8. spring的aop准备工作-导包定义通知
  9. SpringBoot整合 Shiro
  10. 列表隔行变色、显示和隐藏下拉菜单、列表的高亮显示效果