传送门:

  [1]:BZOJ

  [2]:洛谷

•题意

  求串 s 中出现的所有奇回文串,并按照长度由大到小排序;

  输出前 k 个奇回文串的乘积 mod 19930726;

  如果奇回文串的个数不足 k 个,输出 -1;

•题解

  将串 s 跑一边回文自动机;

  将求解出的 len,cnt 数组存入一个结构体中并按照 len 由大到小排序;

  将前 k 个奇回文串的长度相乘就行;

  记得用快速幂,并且只要奇回文串的长度乘积;

•Code

 #include<bits/stdc++.h>
using namespace std;
#define ll long long
const int MOD=;
const int maxn=1e6+; int n;
ll k;
char s[maxn]; struct PAM
{
int tot;
int last;
ll cnt[maxn];
ll len[maxn];
int fail[maxn];
int son[maxn][]; int newNode(int Len)
{
for(int i=;i < ;++i)
son[tot][i]=; len[tot]=Len;
fail[tot]=;
cnt[tot]=; return tot++;
}
int getFail(int p,int i)
{
while(s[i-len[p]-] != s[i])
p=fail[p];
return p;
}
void Init()
{
tot=;
last=; newNode();
newNode(-); fail[]=;
}
void Count()
{
for(int i=tot-;i >= ;--i)
cnt[fail[i]] += cnt[i];
}
void pam()
{
Init(); for(int i=;i <= n;++i)
{
s[i]=s[i]-'a'+; int cur=getFail(last,i); if(!son[cur][s[i]])
{
int now=newNode(len[cur]+);
fail[now]=son[getFail(fail[cur],i)][s[i]];
son[cur][s[i]]=now; }
cnt[last=son[cur][s[i]]]++;
}
Count();
}
}_pam;
struct Data
{
ll cnt;
ll len;
bool operator < (const Data &obj) const
{
return len > obj.len;
}
}a[maxn]; ll qPow(ll a,ll b,ll m)
{
ll ans=;
a %= m;
while(b)
{
if(b&)
ans=ans*a%m;
a=a*a%m;
b >>= ;
}
return ans;
}
int main()
{
scanf("%d%lld",&n,&k);
scanf("%s",s+);
s[]='#'; _pam.pam(); int x=;
for(int i=;i < _pam.tot;i++)
a[++x]=Data{_pam.cnt[i],_pam.len[i]}; sort(a+,a+x+); int index=;
ll ans=;
while(index <= x)
{
if(!(a[index].len&))///坑:如果不是奇回文串,continue
{
index++;
continue;
} ll cur=min(k,a[index].cnt); ans *= qPow(a[index++].len,cur,MOD);
ans %= MOD;
k -= cur; if(k == )
break;
}
if(k > )
ans=-; printf("%lld\n",ans);
}

BZOJ 2160: 拉拉队排练(回文树)的更多相关文章

  1. bzoj 2160: 拉拉队排练 回文自动机

    题目: Description 艾利斯顿商学院篮球队要参加一年一度的市篮球比赛了.拉拉队是篮球比赛的一个看点,好的拉拉队往往能帮助球队增加士气,赢得最终的比赛.所以作为拉拉队队长的楚雨荨同学知道,帮助 ...

  2. BZOJ2160拉拉队排练——回文自动机

    题目描述 艾利斯顿商学院篮球队要参加一年一度的市篮球比赛了.拉拉队是篮球比赛的一个看点,好的拉拉队往往能帮助球队增加士气,赢得最终的比赛.所以作为拉拉队队长的楚雨荨同学知道,帮助篮球队训练好拉拉队有多 ...

  3. BZOJ 2160: 拉拉队排练

    Description 问长度前 \(k\) 大的奇长度回文子串的乘积. Sol Manacher. 直接马拉车跑一边,统计一下答案,每次将长度-2就可以了. Code /************** ...

  4. BZOJ.2160.拉拉队排练(Manacher)

    题目链接 \(Description\) 求给定字符串中 最长的k个回文串长度的乘积(要求回文串长度为奇数):若奇数长度回文串不足k个则输出-1.(len<=10^6,k<=10^12) ...

  5. 【BZOJ2342】双倍回文(回文树)

    [BZOJ2342]双倍回文(回文树) 题面 BZOJ 题解 构建出回文树之后 在\(fail\)树上进行\(dp\) 如果一个点代表的回文串长度为\(4\)的倍数 并且存在长度为它的一半的回文后缀 ...

  6. HYSBZ 2160 拉拉队排练(回文树)

    2160: 拉拉队排练 Time Limit: 10 Sec  Memory Limit: 259 MB Submit: 825  Solved: 324 [Submit][Status][Discu ...

  7. 【BZOJ2160】拉拉队排练(回文树)

    [BZOJ2160]拉拉队排练(回文树) 题面 BZOJ 题解 看着题目, 直接构建回文树 求出每个回文串的出现次数 直接按照长度\(sort\)一下就行了 然后快速幂算一下答案就出来了 这题貌似可以 ...

  8. [回文树][BZOJ2160][国家集训队]拉拉队排练

    题面 Description 艾利斯顿商学院篮球队要参加一年一度的市篮球比赛了.拉拉队是篮球比赛的一个看点,好的拉拉队往往能帮助球队增加士气,赢得最终的比赛.所以作为拉拉队队长的楚雨荨同学知道,帮助篮 ...

  9. 【BZOJ】2160: 拉拉队排练(Manacher)

    题目 2160: 拉拉队排练 Description 艾利斯顿商学院篮球队要参加一年一度的市篮球比赛了.拉拉队是篮球比赛的一个看点,好的拉拉队往往能帮助球队增加士气,赢得最终的比赛.所以作为拉拉队队长 ...

随机推荐

  1. 去掉goland中间的令人烦躁的竖线

    去掉“configured in code Style options”前面的勾即可.

  2. Liferay 7 OSGi第三方jar包依赖问题

    发现遇到这个问题的人挺多的,现在跟新一下好好写. 在开发Liferay的时候,我们常常会遇到Unresolved requirement: Import-Package: {package name} ...

  3. laravel 分页带参数

    {{$data->appends(request()->except(['page']))->links()}}

  4. 洛谷P2051 中国象棋

    题目描述 这次小可可想解决的难题和中国象棋有关,在一个N行M列的棋盘上,让你放若干个炮(可以是0个),使得没有一个炮可以攻击到另一个炮,请问有多少种放置方法.大家肯定很清楚,在中国象棋中炮的行走方式是 ...

  5. 解决VS+Qt不生成moc文件问题

    使用VS的Qt插件进行Qt开发时,有时候会遇到不能生成moc文件的问题. 1.在工程中可以看到这个Generated files目录下是有一个看似moc文件的文件,双击打开的话: 如果能正常打开,文件 ...

  6. 【NS2】trace 文件格式(转载)

    本文档是对 http://nsnam.isi.edu/nsnam/index.php/NS-2_Trace_Formats > 的翻译. 译注:本文描述的无线格Trace格式已经有些陈旧,现在一 ...

  7. 前端基础☞html

    HTML 初识 web服务本质 import socket def main(): sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s ...

  8. HDFS 通信接口

  9. oracle函数 sysdate

    [功能]:返回当前日期. [参数]:没有参数,没有括号 [返回]:日期 [示例]select sysdate  hz from dual; 返回:2008-11-5

  10. laravel 5 自定义全局函数,怎么弄呢?

    在app/Helpers/(目录可以自己随便来) 下新建一个文件 functions.php 在functions.php 中加入这个方法 然后在 bootstrap/autoload.php 中添加 ...