洛谷P3805 【模板】manacher
题目链接:https://www.luogu.com.cn/problem/P3805
manacher算法模板题。
参考资料:https://oi-wiki.org/string/manacher/
示例程序:
#include <bits/stdc++.h>
using namespace std;
const int maxn = 2.2e7 + 5;
int n;
char s[maxn/2], a[maxn];
int p[maxn];
void init() {
int m = 0;
a[m++] = '$';
a[m++] = '#';
for (int i = 0; i < n; i++)
a[m++] = s[i], a[m++] = '#';
a[m++] = '^';
n = m;
}
void manacher() {
int mr = 0, mid;
for (int i = 1; i < n; i++) {
if (i < mr) p[i] = min(p[mid * 2 - i], mr - i);
else p[i] = 1;
while (a[i - p[i]] == a[i + p[i]]) p[i]++;
if (i + p[i] > mr)
mr = i + p[i], mid = i;
}
}
int main() {
scanf("%s", s);
n = strlen(s);
init();
manacher();
int res = 0;
for (int i = 0; i < n; i++)
res = max(res, p[i]);
printf("%d\n", res - 1);
return 0;
}
标签:
manacher
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
· 为什么 退出登录 或 修改密码 无法使 token 失效
2022-10-31 洛谷P8775 [蓝桥杯 2022 省 A] 青蛙过河 题解 贪心+二分答案