博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【洛谷 P1659】 [国家集训队]拉拉队排练(manacher)
阅读量:6252 次
发布时间:2019-06-22

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

马拉车+简单膜你

#include 
#include
#include
using namespace std;const int MAXN = 11000010;const int MOD = 19930726;char b[MAXN], a[MAXN << 1];int hw[MAXN << 1], ans = 1, n, c[MAXN];#define ll long longll now, m;int fast_pow(int a, ll k){ int ans = 1; while(k){ if(k & 1) ans = (ll)ans * a % MOD; a = (ll) a * a % MOD; k >>= 1; } return ans;}int main(){ scanf("%d%lld", &n, &m); scanf("%s", b); a[0] = a[1] = '#'; for(int i = 0; i < n; ++i) a[(i << 1) + 2] = b[i], a[(i << 1) + 3] = '#'; int maxright = 0, mid; n = (n << 1) + 3; for(int i = 1; i < n; ++i){ if(i < maxright) hw[i] = min(hw[(mid << 1) - i], hw[mid] + mid - i); else hw[i] = 1; while(a[i + hw[i]] == a[i - hw[i]]) ++hw[i]; if(hw[i] + i > maxright){ maxright = hw[i] + i; mid = i; } ++c[hw[i] - 1]; } for(int i = (n - 3) >> 1; i; --i){ if(i & 1 ^ 1) continue; now += c[i]; if(m <= now){ ans = (ll) ans * fast_pow(i, m) % MOD; m = 0; break; } m -= now; ans = (ll) ans * fast_pow(i, now) % MOD; } if(m) ans = -1; printf("%d\n", ans); return 0;}

转载于:https://www.cnblogs.com/Qihoo360/p/10848541.html

你可能感兴趣的文章
迭代器(Iterable)和for..in..的三种协议
查看>>
判断浏览器是否为顶层窗口
查看>>
数据结构化与保存
查看>>
跨域iframe高度自适应(兼容IE/FF/OP/Chrome)
查看>>
服务器设计笔记(3)-----消息队列
查看>>
poj 1797 Heavy Transportation(最短路径Dijkdtra)
查看>>
基于WinDbg的内存泄漏分析
查看>>
气象预警采集及推送
查看>>
【SSH网上商城项目实战29】使用JsChart技术在后台显示商品销售报表
查看>>
python 基础复习 09 之基础函数
查看>>
Extjs 4
查看>>
Java内存模型(JMM)以及 垃圾回收机制 小结
查看>>
开源3D游戏引擎Irrlicht简介
查看>>
如何花更少的时间学习更多的知识
查看>>
学习鸟哥的Linux私房菜笔记(8)——文件查找与文件管理2
查看>>
day04 列表 增删改查 元组 range
查看>>
php 调用百度sms来发送短信的实现示例
查看>>
基于canvas的原生JS时钟效果
查看>>
PL/SQL查看表结构
查看>>
JSON的学习理解
查看>>