热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

bzoj2565(最长双回文串记录每个位置的后缀最长回文串)

题目正反两边PAM,记录每个位置向左延伸向右延伸的最长回文串的长度。#include#include#include

题目
在这里插入图片描述正反两边PAM,记录每个位置向左延伸向右延伸的最长回文串的长度。

#include
#include
#include
using namespace std;
const int N=1e5+5,Max=26;
//记录一个以i为下标结尾得最长的字符串的长度
struct PAM{int nex[N][26],fail[N],s[N],len[N],ans[N],las,tot,n;int newnode(int le){for(int i&#61;0;i<Max;&#43;&#43;i) nex[tot][i]&#61;0;len[tot]&#61;le;return tot&#43;&#43;;}void init(){tot&#61;0,newnode(0),newnode(-1);n&#61;las&#61;0,s[0]&#61;-1,fail[0]&#61;1;}int get_fail(int x){while(s[n-len[x]-1]!&#61;s[n]) x&#61;fail[x];return x;}void add(int c,int pos){c-&#61;&#39;a&#39;,s[&#43;&#43;n]&#61;c;int cur&#61;get_fail(las);if(!nex[cur][c]){int now&#61;newnode(len[cur]&#43;2);fail[now]&#61;nex[get_fail(fail[cur])][c];nex[cur][c]&#61;now;}las&#61;nex[cur][c],ans[pos]&#61;len[las];//以pos这个位置的最长后缀回文串的长度为len[las]。}
}A,B;
char s[N];
int main(){scanf("%s",s&#43;1);int len&#61;strlen(s&#43;1);A.init();for(int i&#61;1;i<&#61;len;&#43;&#43;i) A.add(s[i],i);//向左最长的后缀回文串B.init();for(int i&#61;len;i>&#61;1;--i) B.add(s[i],i);//向右最长的前缀回文串(倒过来就是后缀回文串哦)int res&#61;0;for(int i&#61;1;i<len;&#43;&#43;i) res&#61;max(res,A.ans[i]&#43;B.ans[i&#43;1]);printf("%d\n",res);
}


推荐阅读
  • 本文介绍了Linux系统中的文件IO操作,包括文件描述符、基本文件操作函数以及目录操作。详细解释了各个函数的参数和返回值,并提供了代码示例。 ... [详细]
  • 本文介绍了一种解决二元可满足性(2-SAT)问题的方法。通过具体实例,详细解释了如何构建模型、应用算法,并提供了编程实现的细节和优化建议。 ... [详细]
  • 本题旨在通过给定的评级信息,利用拓扑排序和并查集算法来确定全球 Tetris 高手排行榜。题目要求判断是否可以根据提供的信息生成一个明确的排名表,或者是否存在冲突或信息不足的情况。 ... [详细]
  • 本文深入探讨了POJ2762问题,旨在通过强连通分量缩点和单向连通性的判断方法,解决有向图中任意两点之间的可达性问题。文章详细介绍了算法原理、实现步骤,并附带完整的代码示例。 ... [详细]
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 树链问题的优化解法:深度优先搜索与质因数分解
    本文介绍了一种通过深度优先搜索(DFS)和质因数分解来解决最长树链问题的方法。我们通过枚举树链上的最大公约数(GCD),将所有节点按其质因子分类,并计算每个类别的最长链,最终求得全局最长链。 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • 本文介绍了如何使用Java中的同步方法和同步代码块来实现两个线程的交替打印。一个线程负责打印1到52的数字,另一个线程负责打印A到Z的字母,确保输出顺序为12A34B...5152Z。 ... [详细]
  • 不确定性|放入_华为机试题 HJ9提取不重复的整数
    不确定性|放入_华为机试题 HJ9提取不重复的整数 ... [详细]
  • 在Java中,this是一个引用当前对象的关键字。如何通过this获取并显示其所指向的对象的属性和方法?本文详细解释了this的用法及其背后的原理。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • 本文详细介绍了如何在 Objective-C 中使用 @public 和 @protected 修饰符来控制类成员的访问权限。同时,探讨了点语法和箭头操作符的区别,以及属性声明和实现的自动生成。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
author-avatar
周天芷65486
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有