Description

艾利斯顿商学院篮球队要参加一年一度的市篮球比赛了。拉拉队是篮球比赛的一个看点,好的拉拉队往往能帮助球队增加士气,赢得最终的比赛。所以作为拉拉队队长的楚雨荨同学知道,帮助篮球队训练好拉拉队有多么的重要。拉拉队的选拔工作已经结束,在雨荨和校长的挑选下,n位集优秀的身材、舞技于一体的美女从众多报名的女生中脱颖而出。这些女生将随着篮球队的小伙子们一起,和对手抗衡,为艾利斯顿篮球队加油助威。一个阳光明媚的早晨,雨荨带领拉拉队的队员们开始了排练。n个女生从左到右排成一行,每个人手中都举了一个写有26个小写字母中的某一个的牌子,在比赛的时候挥舞,为小伙子们呐喊、加油。雨荨发现,如果连续的一段女生,有奇数个,并且他们手中的牌子所写的字母,从左到右和从右到左读起来一样,那么这一段女生就被称作和谐小群体。现在雨荨想找出所有和谐小群体,并且按照女生的个数降序排序之后,前K个和谐小群体的女生个数的乘积是多少。由于答案可能很大,雨荨只要你告诉她,答案除以19930726的余数是多少就行了。

Input

输入为标准输入。第一行为两个正整数n和K,代表的东西在题目描述中已经叙述。接下来一行为n个字符,代表从左到右女生拿的牌子上写的字母。

Output

输出为标准输出。输出一个整数,代表题目描述中所写的乘积除以19930726的余数,如果总的和谐小群体个数小于K,输出一个整数-1。

Sample Input

5 3
ababa

Sample Output

45
【样例说明】
和谐小群体女生所拿牌子上写的字母从左到右按照女生个数降序排序后为ababa, aba, aba, bab, a, a, a, b, b,前三个长度的乘积为。

HINT

总共20个测试点,数据范围满足:

Solution

对于每一个长为L的奇回文串,显然ta包含的和谐团体为1~L的奇回文串
求出len数组后,每一个和谐团体就可以很容易用前缀和求解
最后用快速幂统计一下答案即可。

Code

 #include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#define N (2000000+1000)
#define MOD (19930726)
using namespace std; long long n,k,tot,len[N],sum[N];
char a[N],s[N]; long long Qpow(long long a,long long b,long long p)
{
long long ans=,base=a;
while (b!=)
{
if (b&) ans=ans*base%p;
base=base*base%p; b>>=;
}
return ans;
} void Manacher()
{
long long x,mid=,maxn=;
for (int i=; i<=tot; ++i)
{
if (i>maxn) x=;
else x=min(maxn-i+,len[mid*-i]);
while (s[i+x]==s[i-x]) x++;
len[i]=x;
if (i+x->maxn) maxn=i+x-,mid=i;
}
} int main()
{
scanf("%lld%lld%s",&n,&k,a); s[++tot]='@'; s[++tot]='#';
for (int i=; i<n; ++i)
s[++tot]=a[i], s[++tot]='#';
s[++tot]='$';
Manacher(); for (int i=; i<tot-; i+=)
sum[]++,sum[len[i]]--;
for (int i=; i<=tot; ++i)
sum[i]+=sum[i-]; long long ans=;
for (int i=n%?n:n-; i>=; i-=)
if (sum[i]<=k) (ans*=Qpow(i,sum[i],MOD))%=MOD,k-=sum[i];
else {(ans*=Qpow(i,k,MOD))%=MOD; break;}
printf("%lld",ans);
}

最新文章

  1. Oracle PL/SQL随堂笔记总结
  2. Web Analytics 2.0 中文翻译 [ 系列索引 ]
  3. PXE网络启动提示no default or ui configuration directive问题解决
  4. #一周五# VS2015 CTP6, TFS2015 CTP1更新,老衣的开发工具汇总,2015 MVP 社区巡讲
  5. gcc-5.4.0 static dwarf2 compile
  6. jq查找父类元素三个函数的区别
  7. LINUX DIFF命令详解
  8. .net 下载图片
  9. 【leetcode】Word Ladder (hard) ★
  10. php模板引擎
  11. Common lisp菜鸟指南(译)
  12. mysql 备份数据
  13. Python中的sys.path.append()
  14. 时间序列分析 异常分析 stl
  15. VxWorks信号量问题
  16. 怎样从外网访问内网Resin
  17. 深入浅出javascript(五)函数
  18. xp_readerrorlog与sp_readerrorlog
  19. 界面编程之QT的数据库操作20180801
  20. 本地sql大文件导入数据库

热门文章

  1. 第4天:function对象(案例:获取当前日期属于当年第几天、arguments对象、函数类型、参数、返回值、自身调用)
  2. 基于svg.js实现对图形的拖拽、选择和编辑操作
  3. jQuery实现18位身份证输入隔位添加空格及格式验证
  4. 解决Maven引用POI的依赖,XSSFWorkbook依旧无法使用的问题
  5. Linux文件系统简介----转载
  6. 批量删除微博的js代码
  7. Python爬虫教程-20-xml 简介
  8. 基于Vue的WebApp项目开发(一)
  9. C# GDI+ 利用 Rectangle GraphicsPath 判断 矩形或多边形 图形关系
  10. Mysql 优化配置2