HDU-3608 最长回文
2024-08-26 10:45:00
HDU-3608 最长回文
题面
Problem Description
给出一个只由小写英文字符a,b,c...y,z组成的字符串S,求S中最长回文串的长度.
回文就是正反读都是一样的字符串,如aba, abba等
Input
输入有多组case,不超过120组,每组输入为一行小写英文字符a,b,c...y,z组成的字符串S
两组case之间由空行隔开(该空行不用处理)
字符串长度len <= 110000
Output
每一行一个整数x,对应一组case,表示该组case的字符串中所包含的最长回文长度.
题意
给一个字符串 求出他的最长回文。用KMP也行。学习一下Manacher吧=w=
不关同步直接TLE,关同步就可以辣
代码
#include <bits/stdc++.h>
using namespace std;
string d;
char a[220010];
int p[220020];
int cnt;
int id,maxid;
int manacher()
{
memset(a,0,sizeof a);
memset(p,0,sizeof p);
cnt=id=maxid=0;
a[0]='$';
for (int i=0;i<d.size();i++) a[++cnt]='#',a[++cnt]=d[i];
a[++cnt]='#';
for (int i=1;i<=cnt;i++)
{
if (maxid>i)
{
p[i]=min(p[2*id-i],maxid-i);
}
else
{
p[i]=1;
}
while (a[i+p[i]]==a[i-p[i]]) p[i]++;
if (i+p[i]>maxid)
{
id=i;
maxid=i+p[i];
}
}
int ans=0;
for (int i=1;i<=cnt;i++) ans=max(ans,p[i]-1);
return ans;
}
int main()
{
ios::sync_with_stdio(false);
while (cin>>d)
cout<<manacher()<<endl;
}
题目链接
http://acm.hdu.edu.cn/showproblem.php?pid=3068
最新文章
- pysvn安装及常用方法
- 机器学习之分类器性能指标之ROC曲线、AUC值
- 多线程Server client
- shell中 ";"; 跟 &#39;&#39;的区别
- win server 2008配置ftp无法登陆问题的解决办法
- 国内最快的jquery cdn
- Xamarin for OSX – SetUp
- FineUI按钮控件
- 在centos7中手动编译greenplum
- sourcetree跳过注册的方法
- WeTest----如何使用WeTest进行App性能测试?
- Asp.net MVC 中 CodeFirst 开发模式实例
- javascript websocket 心跳检测机制介绍
- Leetcode#832. Flipping an Image(翻转图像)
- 从零开始学 Web 之 jQuery(二)获取和操作元素的属性
- [转载]说说JSON和JSONP,也许你会豁然开朗,含jQuery用例
- session(会话)研究(一)基础
- 看似无参却有参-----JS中的函数传参
- [Lua快速了解一下]Lua的OOP
- Linux IO
热门文章
- ELK日志系统:Filebeat使用及Kibana如何设置登录认证(转)
- position的absolute与fixed,absolute与relative共同点与不同点
- IntelliJ IDEA return null with ClassLoader.getSystemResourceAsStream(“configFilename”));
- 一个命令查看mysql的所有配置(原创)
- 自适应手机网站meta name代码
- PAT 1071 小赌怡情(15)(代码)
- js 闭包 弊端
- python多线程下载网页图片并保存至特定目录
- C/C++常用预处理指令
- Codeforces 545E. Paths and Trees 最短路