求一个字符串的最长子串,Manacher算法是一种O(n)的算法,很给力!

s2[0] = '$',是避免在循环中对数组越界的检查。

老大的代码:

http://www.cnblogs.com/BigBallon/p/3816890.html

详细的图解:

http://blog.csdn.net/xingyeyongheng/article/details/9310555

模板题,没有什么好说的。Manacher算法本身确实是要好好理解体会的。

  1. #define LOCAL
  2. #include <iostream>
  3. #include <cstdio>
  4. #include <cstring>
  5. #include <algorithm>
  6. using namespace std;
  7.  
  8. const int maxn = + ;
  9. char s1[maxn], s2[maxn * ];
  10. int p[maxn * ];
  11.  
  12. void init(char s1[], char s2[])
  13. {
  14. s2[] = '$', s2[] = '#';
  15. int j = ;
  16. for(int i = ; s1[i] != '\0'; ++i)
  17. {
  18. s2[j++] = s1[i];
  19. s2[j++] = '#';
  20. }
  21. s2[j] = '\0';
  22. }
  23.  
  24. void manacher(char s[])
  25. {
  26. int id, mx = ;
  27. p[] = ;
  28. for(int i = ; s[i] != '\0'; ++i)
  29. {
  30. if(mx > i)
  31. p[i] = min(p[*id-i], mx - i);
  32. else
  33. p[i] = ;
  34. while(s[i+p[i]] == s[i-p[i]])
  35. ++p[i];
  36. if(i + p[i] > mx)
  37. {
  38. mx = i + p[i];
  39. id = i;
  40. }
  41. }
  42. }
  43.  
  44. void getans(void)
  45. {
  46. int ans = ;
  47. for(int i = ; s2[i] != '\0'; ++i)
  48. ans = max(ans, p[i] - );
  49. printf("%d\n", ans);
  50. }
  51.  
  52. int main(void)
  53. {
  54. #ifdef LOCAL
  55. freopen("3068in.txt", "r", stdin);
  56. #endif
  57.  
  58. while(scanf("%s", s1) != EOF)
  59. {
  60. init(s1, s2);
  61. manacher(s2);
  62. getans();
  63. }
  64. return ;
  65. }

代码君

HDU 3068 (Manacher) 最长回文的更多相关文章

  1. HDU 3068:最长回文(Manacher算法)

    http://acm.hdu.edu.cn/showproblem.php?pid=3068 最长回文 Problem Description   给出一个只由小写英文字符a,b,c...y,z组成的 ...

  2. 【HDU 3068】 最长回文

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=3068 [算法] Manacher算法求最长回文子串 [代码] #include<bits/s ...

  3. HDU 3068 最长回文 (Manacher最长回文串)

    Problem Description 给出一个只由小写英文字符a,b,c...y,z组成的字符串S,求S中最长回文串的长度.回文就是正反读都是一样的字符串,如aba, abba等   Input 输 ...

  4. Hdu 3294 Girls' research (manacher 最长回文串)

    题目链接: Hdu 3294  Girls' research 题目描述: 给出一串字符串代表暗码,暗码字符是通过明码循环移位得到的,比如给定b,就有b == a,c == b,d == c,.... ...

  5. 【HDOJ】【3068】最长回文

    Manacher算法 Manacher模板题…… //HDOJ 3068 #include<cstdio> #include<cstring> #include<cstd ...

  6. Manacher 最长回文子串。

    最长回文子串就是一个字符串的一个子串,他从左往右读和从右往左读是一样的. 可以用 Manacher 算法来求,他的复杂度是 O(n) . 可以看这篇文章 http://blog.csdn.net/yw ...

  7. hdu----(4513)吉哥系列故事——完美队形II(manacher(最长回文串算法))

    吉哥系列故事——完美队形II Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)To ...

  8. POJ3974 Palindrome Manacher 最长回文子串模板

    这道题可以$O(nlogn)$,当然也可以$O(n)$做啦$qwq$ $O(nlogn)$的思路是枚举每个回文中心,通过哈希预处理出前缀和后缀哈希值备用,然后二分回文串的长度,具体的就是判断在长度范围 ...

  9. manacher 最长回文子串

    确定当前已知能匹配到的最长处,看是否要更新最长 #include <bits/stdc++.h> using namespace std; const int N = 210005; in ...

随机推荐

  1. Sqli-labs less 40

    Less-40 本关的sql语句为SELECT * FROM users WHERE id=('$id') LIMIT 0,1 我们根据sql语句构造以下的payload: http://127.0. ...

  2. Using the viewport meta tag to control layout on mobile browsers

    A typical mobile-optimized site contains something like the following: <meta name="viewport& ...

  3. 时序列数据库武斗大会之 OpenTSDB 篇

    [编者按] 刘斌,OneAPM后端研发工程师,拥有10多年编程经验,参与过大型金融.通信以及Android手机操作系的开发,熟悉Linux及后台开发技术.曾参与翻译过<第一本Docker书> ...

  4. IDTHook 深入学习

    在之前的一篇文章中介绍了替换IDT向量表中的地址来达到Hook的目的 IDT hook KiTrap03 但是这样很容易就可以被检测了.接下来要学习就是通过patch GDT来达到Hook IDT的目 ...

  5. 【poj1284-Primitive Roots】欧拉函数-奇素数的原根个数

    http://poj.org/problem?id=1284 题意:给定一个奇素数p,求p的原根个数. 原根: { (xi mod p) | 1 <= i <= p-1 } is equa ...

  6. C# 使用WIN32API设置外部程序窗口无边框

    使用代码 var wnd = win32.FindWindowA(null, "窗口标题"); Int32 wndStyle = win32.GetWindowLong(wnd, ...

  7. lintcode:移动零

    题目 给一个数组 nums 写一个函数将 0 移动到数组的最后面,非零元素保持原数组的顺序 注意事项 1.必须在原数组上操作2.最小化操作数   样例 给出 nums = [0, 1, 0, 3, 1 ...

  8. VS2010/MFC编程入门之五(MFC消息映射机制概述)

    VS2010/MFC编程入门之五(MFC消息映射机制概述)-软件开发-鸡啄米 http://www.jizhuomi.com/software/147.html 上一讲鸡啄米为大家简单分析了MFC应用 ...

  9. google 访问

    http://maolihui.com/goagent-detail.htmlgoagent教程详细版https://aiguge.xyz/chrome-goagent-proxy-switchyom ...

  10. Redhat6下安装QEMU

    Redhat6下安装QEMU 1.下载QEUM:http://wiki.qemu.org/Download 2.解压qemu-1.6.1.tar.bz2到/tmp目录(也可以是其他目录)下,并进入解压 ...