UESTC-1975弗吉桑(回文串,manacher算法)
弗吉桑
Time Limit: 3000 MS Memory Limit: 64 MB
弗吉桑是一座横跨清水河大草原的活火山,位于子科技大学主楼东北方约 80km 处,主峰海拔 3776m , 2002 年 8 月经电子科大校土局重新测量后,为 3775.63m 。
闻名全球的弗吉桑是清水河最重要的象征之一,被视为圣山。弗吉桑与大草原、牧犬羊并列为清水河的校园象征……
对不起扯远了。
校土局希望测量弗吉桑的宽度,于是每隔一定距离测量了经过清水河大草原的多个截面中各处的海拔高度。
由于弗吉桑高度对称,所以我们认为截面中最长的连续对称海拔高度子串即为弗吉桑的宽度。注:题目没说弗吉桑就一定长着个山的形状。
由于服务器沉迷运行 Minecraft 无法自拔,导致学校算力不足。校土局希望借用三万女工的力量测量出弗吉桑的宽度。作为万千女工中的一员,你当然希望早点下班回家陪陪丈夫孩子。
你想到了一个绝妙的主意……
说人话:求最长回文串长度
Input
多组测试数据,输入第一行一个小于 100 的正整数 TT 表示测试组数。
对于每组数据,第一行一个正整数 nn ( 1≤n≤1051≤n≤105 ) ,表示某个截面上测量的海拔总个数。
接下来一行包含 nn 个非负整数 hihi ( 0≤hi≤1090≤hi≤109 ) 表示海拔高度。
Output
每组测试数据一行,输出弗吉桑的宽度。
Sample input and output
Sample Input | Sample Output |
---|---|
2 |
5 |
Hint
样例第一组数据:
样例第二组数据:
Source
ac代码为:
#include<bits/stdc++.h>
using namespace std;
const int maxn=3e5;
int s[maxn],str[maxn];
int p[maxn],len2,len1;
void init(int n)
{
len1=n;
str[0]=-1;
for(int i=1;i<=2*len1;i+=2)
{
str[i]=-2;
str[i+1]=s[i/2];
}
str[2*len1+1]=-2;
str[2*len1+2]=-3;
//str[2*len1+3]=-4;
len2=2*len1+1;
}
int manacher()
{
int mx=0,ans=0,po=0;
for(int i=1;i<=len2;i++)
{
if(mx>i)
p[i]=min(mx-i,p[2*po-i]);
else
p[i]=1;
while(str[i-p[i]]==str[i+p[i]]) p[i]++;
if(p[i]+i>mx)
{
mx=p[i]+i;
po=i;
}
ans=max(ans,p[i]);
}
return ans-1;
}
int main()
{
int T,n,num;
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=0;i<n;i++) scanf("%d",&num),s[i]=num;
init(n);
printf("%d\n",manacher());
}
return 0;
}
UESTC-1975弗吉桑(回文串,manacher算法)的更多相关文章
- 回文串--Manacher算法(模板)
用途:在O(n)时间内,求出以每一个点为中心的回文串长度. 首先,有一个非常巧妙的转化.由于回文串长度有可能为奇数也有可能为偶数,说明回文中心不一定在一个字符上.所以要将字符串做如下处理:在每两个字母 ...
- luoguP4555 [国家集训队]最长双回文串 manacher算法
不算很难的一道题吧.... 很容易想到枚举断点,之后需要处理出以$i$为开头的最长回文串的长度和以$i$为结尾的最长回文串的长度 分别记为$L[i]$和$R[i]$ 由于求$R[i]$相当于把$L[i ...
- bzoj 2565: 最长双回文串 manacher算法
2565: 最长双回文串 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/problem. ...
- 最长回文---hdu3068 (回文串 manacher 算法模板)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3068 题意很清楚:就是求一个串s的子串中最长回文串的长度:这类题用到了manacher算法 #incl ...
- 37:密码截取(回文串manacher算法)
题目描述:Catcher是MCA国的情报员,他工作时发现敌国会用一些对称的密码进行通信,比如像这些ABBA,ABA,A,123321,但是他们有时会在开始或结束时加入一些无关的字符以防止别国破解.比如 ...
- 【BZOJ2565】最长双回文串 (Manacher算法)
题目: BZOJ2565 分析: 首先看到回文串,肯定能想到Manacher算法.下文中字符串\(s\)是输入的字符串\(str\)在Manacher算法中添加了字符'#'后的字符串 (构造方式如下) ...
- HDU3068 回文串 Manacher算法
好久没有刷题了,虽然参加过ACM,但是始终没有融会贯通,没有学个彻底.我干啥都是半吊子,一瓶子不满半瓶子晃荡. 就连简单的Manacher算法我也没有刷过,常常为岁月蹉跎而感到后悔. 问题描述 给定一 ...
- Palindrome(最长回文串manacher算法)O(n)
Palindrome Time Limit:15000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit ...
- 九度OJ 1528 最长回文子串 -- Manacher算法
题目地址:http://ac.jobdu.com/problem.php?pid=1528 题目描述: 回文串就是一个正读和反读都一样的字符串,比如"level"或者"n ...
随机推荐
- libpcap的下载与安装(apt-get安装unable to locate package 的解决方法(Ubantu))
因为网络安全课的实验课要求,我们得下载libcap我们得做一个类似于tcpdump的一个东西.具体要求就不贴出来了. libpcap只能在官网(www.tcpdump.org)下到,我用的os是Ubu ...
- tornado的使用-数据库篇
tornado的使用-数据库篇
- thinkphp 比RBAC更好的权限认证方式(Auth类认证)
Auth 类已经在ThinkPHP代码仓库中存在很久了,但是因为一直没有出过它的教程, 很少人知道它, 它其实比RBAC更方便 . RBAC是按节点进行认证的,如果要控制比节点更细的权限就有点困难了, ...
- PHP 核心特性 - 命名空间
提出 在命名空间提出之前,不同的组件很容易碰到命名的冲突,例如 Request .Response 等常见的命名.PHP 在 5.3 后提出了命名空间用来解决组件之间的命名冲突问题,主要参考了文件系统 ...
- nyoj 1 A + B Problme
A+B Problem 时间限制:3000 ms | 内存限制:65535 KB |难度:0 描述 此题为练手用题,请大家计算一下a+b的值. 输入 输入两个数,a,b 输出 输出a+b的值 样例 ...
- nyoj 83-迷宫寻宝(二) (计算几何, 叉积)
83-迷宫寻宝(二) 内存限制:10MB 时间限制:1000ms 特判: No 通过数:2 提交数:6 难度:5 题目描述: 一个叫ACM的寻宝者找到了一个藏宝图,它根据藏宝图找到了一个迷宫,这是一个 ...
- (三)初识NumPy(数据CSV文件存取和多维数据的存取)
本章主要介绍的是数据的CSV文件存取和多维数据的存取. 一.数据的CSV文件存取 1.CSV的写文件: np.savetxt(frame, array, fmt='%.18e', delimiter= ...
- 爬虫多线程模板,xpath,etree
class QuiShi: def __init__(self): self.temp_url = "http://www.lovehhy.net/Joke/Detail/QSBK/{0}& ...
- Centos上通过shell脚本备份数据库
#!/bin/bash ds=`` list=`date +%Y`/`date +%m` dname="callme" eval "mkdir -p $list" ...
- python高阶函数的使用
目录 python高阶函数的使用 1.map 2.reduce 3.filter 4.sorted 5.小结 python高阶函数的使用 1.map Python内建了map()函数,map()函数接 ...