bzoj 2342: 双倍回文 回文自动机】的更多相关文章

题目大意: 定义双倍回文串的左一半和右一半均是回文串的长度为4的倍数的回文串 求一个给定字符串中最长的双倍回文串的长度 题解: 我们知道可以简单地判定以某一点结尾的最长回文串 我们知道可以简单地判定以某一点开头的最长回文串 啥?第二个?你把串倒过来不就行了? 所以我们枚举双倍回文串的断点再判定即可. 我们发现我们每次都要取枚举到的两个端点的最长的相同偶数长度的回文串 并且这两个回文串还要相同..也就是说在回文自动机上这是同一个点 所以我们在fail树上求lca即可 #include <cstdi…
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2342 题意:定义双倍回文串为:串的长度为4的倍数且串的前一半.后一半.串本身均是回文的.给定一个串.求它的一个最长子串为双倍回文串. 思路:首先利用manacher算法计算以每个位置为中心的回文半径.那么枚举位置i(i为添加的字母),对于之前的位置j,若j+ rad[j]>=i,那么可以更新答案.这里j>=i-rad[i]/2. char s1[N],s[N];int n,rad[N…
Link:https://www.lydsy.com/JudgeOnline/problem.php?id=2342 Algorithm: 解决回文串问题,一般从对称轴下手. 肯定先跑一边Manacher,(可以只记录长度为偶数的回文串) 枚举x为“主”对称轴,实际上对称轴在x到x+1之间.这样外层大的回文串wwRwwR就确定了. 接下来就只要枚举一半的回文串wwR的对称轴y了,从而用len(x+1,y)*4更新答案 当且仅当 y-m[y]<=x 并 y<=x+m[x]/2时是符合要求的x和y…
Vue 2.5 发布了:15篇前端热文回看 2017-11-02 前端大全 (点击上方公众号,可快速关注) 本文精选了「前端大全」2017 年 10 月的 15 篇热门文章.其中有职场分享.技术分享和技术资源. 注:以下文章,点击标题即可阅读 <Vue 2.5 发布了> 我们很高兴宣布 Vue 2.5 Level E 的发布!本次发布包括多个功能提升并且我们推荐你查看发布说明来获取完整详细信息. 在这篇文章中,我们将重点介绍一些更重要的的变化:更好的 TypeScript 集成,更好的错误处理…
摘自:http://blog.csdn.net/VhWfR2u02Q/article/details/78993079 注:以下文章,点击标题即可阅读 <6 大主流 Web 框架优缺点对比> 是该读些评论和做一些总结的时候了.当我们开始写这个系列博客的时候,我们知道 JavaScript/web 应用框架并不太好总结.我们努力对这个不可回答的问题作出回答:我该用什么样的框架? <可能是目前最完整的前端框架 Vue.js 全面介绍> 2016年最火的前端框架当属Vue.js了,很多使…
题目链接:BZOJ - 3530 题目分析 明显是 AC自动机+DP,外加数位统计. WZY 神犇出的良心省选题,然而去年我太弱..比现在还要弱得多.. 其实现在做这道题,我自己也没想出完整解法.. 就想出了个 O(l^3) 的做法: 完全按照数位统计的思想来,先统计长度不足 len 的数字的合法种类数,这个枚举开头,然后 AC 自动机 DP 一下,用 f[i][j] 表示到了第 i 位,在第 j 个节点上的合法数字个数.这样是 O(L^2). 然后长度等于 n 的部分,就按照数位统计,一位位向…
题目大意:略 先建出$PAM$ 因为双倍回文串一定是4的倍数,所以找出$PAM$里所有$dep$能整除4的节点 看这个串是否存在一个回文后缀,长度恰好为它的一半,沿着$pre$链往上跳就行了 暴跳可能会$T$,所以倍增了跳 如果被卡空间,可以把trs数组当成倍增数组 #include <cmath> #include <vector> #include <cstdio> #include <cstring> #include <algorithm>…
2342: [Shoi2011]双倍回文 Time Limit: 10 Sec Memory Limit: 128 MB Description Input 输入分为两行,第一行为一个整数,表示字符串的长度,第二行有个连续的小写的英文字符,表示字符串的内容. Output 输出文件只有一行,即:输入数据中字符串的最长双倍回文子串的长度,如果双倍回文子串不存在,则输出0. Sample Input 16 ggabaabaabaaball Sample Output 12 HINT N<=50000…
2342: [Shoi2011]双倍回文 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1123  Solved: 408 题目连接 http://www.lydsy.com/JudgeOnline/problem.php?id=2342 Description 输入分为两行,第一行为一个整数n,表示字符串的长度,第二行有n个连续的小写的英文字符,表示字符串的内容. Input 输入分为两行,第一行为一个整数,表示字符串的长度,第二行有个连续的小…
题目链接:双倍回文 回文自动机第二题.构出回文自动机,那么一个回文串是一个“双倍回文”,当且仅当代表这个串的节点\(u\)顺着\(fail\)指针往上跳,可以找到一个节点\(x\)满足\(2len_x=len_u\).当然还需要\(len_u\)是\(4\)的倍数. 然后我们把\(fail\)树构出来,在上面\(dfs\)一遍就做完了. 下面贴代码: #include<iostream> #include<cstdio> #include<cstring> #inclu…