博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 3068 最长回文(manachar求最长回文子串)
阅读量:6258 次
发布时间:2019-06-22

本文共 835 字,大约阅读时间需要 2 分钟。

解题思路:通过manachar算法求最长回文子串,如果用遍历的话绝对超时。

 

#include 
#include
const int N = 220005;int rad[N];char string[N], tmpstr[N];int max(int a, int b) { return a > b ? a : b;}int min(int a, int b) { return a < b ? a : b;}int manachar() { int ans = 0, mix = 0, id = 0, len = strlen(string); for (int i = 1; i <= len; i++) { if (mix > i) rad[i] = min(rad[2 * id - i], mix - i); else rad[i] = 1; for ( ; string[i - rad[i]] == string[i + rad[i]]; rad[i]++) { if (mix < i + rad[i]) { mix = i + rad[i]; id = i; } } ans = max(ans, rad[i]); } return ans - 1;}int main() { while (gets(tmpstr)) { int len = strlen(tmpstr), cnt = 0; string[cnt++] = '$'; for (int i = 0; i <= len; i++) { string[cnt++] = '#'; string[cnt++] = tmpstr[i]; } getchar(); printf("%d\n", manachar()); } return 0;}

 

 

转载地址:http://usxsa.baihongyu.com/

你可能感兴趣的文章
Python IDLE快捷键【转载合集】
查看>>
Bootstrap中glyphicons-halflings-regular.woff字体报404错notfound
查看>>
[C++] string与int, float, double相互转换
查看>>
ubuntu14.04安装chrome
查看>>
oracle中查询含字母的数据[正则表达式]
查看>>
1002. 写这个号码 (20)(数学啊 ZJU_PAT)
查看>>
【LeetCode】224. Basic Calculator
查看>>
Keil V4.72升级到V5.1X之后
查看>>
Google CFO 辞职信
查看>>
POJ2771_Guardian of Decency(二分图/最大独立集=N-最大匹配)
查看>>
Scala深入浅出实战经典之 List伴生对象操作方法代码实战.
查看>>
php 批量处理post数据
查看>>
RESTful架构详解(转)
查看>>
xcode 在哪里新建category、protocol等文件
查看>>
flash flex 程序出现错误 Error #2032
查看>>
【数据库】主键、外键、索引
查看>>
C#解析HTML
查看>>
导出/打印项目数据报表需要设置IE浏览器
查看>>
8个强大的基于Bootstrap的CSS框架
查看>>
MAC OSX在视图port哪个程序占用,杀死进程的方法
查看>>