题目分析:

题目要求前后缀相同,把串反过来之后是一个很明显的卷积的形式。这样我们可以完成初步判断(即可以知道哪些必然不行)。

然后考虑一下虽然卷积结果成立,但是存在问号冲突的情况。

箭头之间应当不存在1。不然就和图上所画的一样。注意到它每隔len个跳一次,所以相当于调和级数,利用原有信息判断即可。

字符串转化的方式有很多种。

代码:

 #include<bits/stdc++.h>
using namespace std; const int maxn = (<<)+; const int mod = ;
const int gg = ; char str[maxn]; int n,m,len,a[maxn<<],b[maxn<<],ord[maxn<<]; int f[maxn<<],iv; int fast_pow(int now,int pw){
int ans = ,dd = now,bit = ;
while(bit <= pw){
if(bit & pw) {ans = (1ll*ans*dd)%mod;}
dd = (1ll*dd*dd)%mod;
bit<<=;
}
return ans;
} void fft(int *d,int dr){
for(register int i=;i<m;i++) if(i < ord[i]) swap(d[i],d[ord[i]]);
for(register int i=;i<m;i<<=){
int wn = fast_pow(gg,(mod-)/(*i));
if(dr == -) wn = fast_pow(wn,mod-);
for(register int j=;j<m;j+=(i<<)){
for(register int k=,w=;k<i;k++,w = (1ll*w*wn)%mod){
int x = d[j+k],y = (1ll*w*d[j+k+i])%mod;
d[j+k] = x+y; d[j+k] >=mod?d[j+k]-=mod:;
d[j+k+i] = x-y;
d[j+k+i] < ?d[j+k+i]+=mod:;
}
}
}
if(dr == -){
for(register int i=;i<m;i++) d[i] = (1ll*d[i]*iv)%mod;
}
} void work(){
int n = strlen(str);m = ;
while(m < *n){m<<=;len++;} iv = fast_pow(m,mod-);
for(register int i=;i<m;i++) ord[i] = (ord[i>>]>>)+((i&)<<len-); for(register int i=;i<n;i++) {
if(str[i] == '') a[i] = ;
else if(str[i] == '') b[n-i-] = ;
} fft(a,); fft(b,);
for(register int i=;i<m;i++) {
f[i] = (1ll*a[i]*b[i])%mod;
} memset(a,,sizeof(a)); memset(b,,sizeof(b)); for(register int i=;i<n;i++) {
if(str[i] == '') a[i] = ;
else if(str[i] == '') b[n-i-] = ;
} fft(a,); fft(b,);
for(register int i=;i<m;i++) {
f[i] += (1ll*a[i]*b[i])%mod; if(f[i] >mod)f[i]-=mod;
} fft(f,-); for(register int i=;i<n-;i++){
int now = n--i;
for(register int j=i-now;j>=;j-=now){
f[i] |= f[j];
}
} long long ans = ;
for(register int i=;i<=n;i++){
ans ^= (1ll*(f[i-]==)*i*i);
}
printf("%lld",ans);
} int main(){
scanf("%s",str);
work();
return ;
}

LOJ6436 [PKUSC2018] 神仙的游戏 【FFT】的更多相关文章

  1. [LOJ6436][PKUSC2018]神仙的游戏

    loj description 给你一个只有01和?的字符串,问你是否存在一种把?改成01的方案使串存在一个长度为\(1-n\)的\(border\).\(n\le5\times10^5\) sol ...

  2. [PKUSC2018]神仙的游戏(FFT)

    给定一个01?串,对所有len询问是否存在一种填法使存在长度为len的border. 首先有个套路的性质:对于一个长度为len的border,这个字符串一定有长度为n-len的循环节(最后可以不完整) ...

  3. BZOJ5372: [Pkusc2018]神仙的游戏

    BZOJ5372: [Pkusc2018]神仙的游戏 https://lydsy.com/JudgeOnline/problem.php?id=5372 分析: 如果\(len\)为\(border\ ...

  4. BZOJ5372: PKUSC2018神仙的游戏

    传送门 Sol 自己还是太 \(naive\) 了,上来就构造多项式和通配符直接匹配,然后遇到 \(border\) 相交的时候就 \(gg\) 了 神仙的游戏蒟蒻还是玩不来 一个小小的性质: 存在长 ...

  5. bzoj 5372: [Pkusc2018]神仙的游戏

    Description 小D和小H是两位神仙.他们经常在一起玩神仙才会玩的一些游戏,比如"口算一个4位数是不是完全平方数". 今天他们发现了一种新的游戏:首先称s长度为len的前缀 ...

  6. loj 6436 PKUSC2018 神仙的游戏

    传送门 好妙蛙 即串\(s\)长度为\(n\)首先考虑如果一个长度为\(len\)的\(border\)存在,当且仅当对所有\(i\in[1,len],s[i]=s[n-len+i]\),也就是所有模 ...

  7. [PKUSC2018]神仙的游戏

    题目 画一画就会发现一些奇诡的性质 首先如果\(len\)为一个\(\operatorname{border}\),那么必然对于\(\forall i\in [1,len]\),都会有\(s_i=s_ ...

  8. BZOJ5372 PKUSC2018神仙的游戏(NTT)

    首先有一个想法,翻转串后直接卷积看有没有0匹配上1.但这是必要而不充分的因为在原串和翻转串中?不能同时取两个值. 先有一些结论: 如果s中长度为len的前缀是border,那么其存在|s|-len的循 ...

  9. 【LOJ6436】【PKUSC2018】神仙的游戏(NTT)

    [LOJ6436][PKUSC2018]神仙的游戏(NTT) 题面 LOJ 题解 看到\(zsy\)从\(PKUSC\)回来就秒掉了这种神仙题 吓得我也赶快看了看\(PKUSC\)都有些什么神仙题 然 ...

随机推荐

  1. Plugin 'Lombok Plugin' is incompatible with this installation

    作者:13 GitHub:https://github.com/ZHENFENG13 版权声明:本文为原创文章,未经允许不得转载. Installation Error Plugin 'Lombok ...

  2. spark 2.3 导致driver OOM的一个SparkPlanGraphWrapper源码的bug

    背景 长话短说,我们部门一个同事找到我,说他的spark 2.3 structured streaming程序频繁报OOM,从来没有坚持过超过三四天的,叫帮看一下. 这种事情一般我是不愿意看的,因为大 ...

  3. 并发连接MySQL

    先吐槽一下libmysqlclientAPI的设计, 多个线程同时去connect居然会core掉. 后来Google了一番, 才发现mysql_real_connect不是线程安全的, 需要一些额外 ...

  4. 两次console.log打印值不同

    var a=[1,2,3] console.log(a); a[2]=10; console.log(a); // 打印结果 // (3) [1, 2, 3] // (3) [1, 2, 10] // ...

  5. python爬虫随笔(2)—启动爬虫与xpath

    启动爬虫 在上一节中,我们已经创建好了我们的scrapy项目,看着这一大堆文件,想必很多人都会一脸懵逼,我们应该怎么启动这个爬虫呢? 既然我们采用cmd命令创建了scrapy爬虫,那就得有始有终有逼格 ...

  6. [2019BUAA软工助教]第一次阅读 - 小结

    [2019BUAA软工助教]第一次阅读 - 小结 一.评分规则 总分 16 分,附加 2 分,共 18 分 markdown格式统一且正确 - 2分 不统一:扣 1 分 不正确:扣 1 分(例如使用代 ...

  7. 如何恢复Eclipse中被误删除的文件

    在使用Eclipse时,可能会不小心误删除一些文件,没关系,Eclipse有个非常强大的功能,能让这些误删除的文件恢复回来,下面就来介绍一下. 工具/原料   Eclipse Kepler 方法/步骤 ...

  8. 使用Browser请求 和 在cli中运行程序的分析

    在browser中请求后端的一个程序之后,立马将窗口关闭,服务器端的程序是否会挂起或者终止,还是继续执行? 如果是继续执行,那么执行完毕后,结果去了哪里?-->apache的工作流程 使用Bro ...

  9. 【学习总结】Markdown 使用的正确姿势

    参考资料:Learning-Markdown 入门参考 注:原博可能对GitHub中的Markdown格式更适用. 有时间可以再GitHub中尝试并写一篇相关攻略. ps:在王熊猫的GitHub里也有 ...

  10. 通过event记录sql

    providers EventServiceProvider.php 添加 protected $listen = [ 'Illuminate\Database\Events\QueryExecute ...