题目分析:

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

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

箭头之间应当不存在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. 领域驱动设计(DDD:Domain-Driven Design) 介绍

    Eric Evans的“Domain-Driven Design领域驱动设计”简称DDD,Evans DDD是一套综合软件系统分析和设计的面向对象建模方法,本站Jdon.com是国内公开最早讨论DDD ...

  2. Pointcut 笔记

    教程 https://blog.csdn.net/kkdelta/article/details/7441829 http://www.cnblogs.com/youse/p/6564524.html ...

  3. Docker镜像的修改和自定义

    一.docker镜像的更新 (1)启动镜像,写入一些文件或者更新软件 docker run -it 3afd47092a0e[root@44652ba46352 /]# ls (2)更新镜像 dock ...

  4. Really Big Numbers CodeForces - 817C (数学规律+二分)

    C. Really Big Numbers time limit per test 1 second memory limit per test 256 megabytes input standar ...

  5. JS闭包以及作用域初探

    以前看到的一个问题,很有意思: for (var i = 0; i < 5; i++) { setTimeout(function () { console.log(i); },500); } ...

  6. Golang开发工具LiteIDE使用方法整理

    安装 参考github的说明 添加GOPATH 创建workspace 创建新文件 运行程序 Liteide中运行程序有两种方式: FR(FileRun)是编译并运行单个文件,可以使用Shift + ...

  7. 爬虫——scrapy框架

    Scrapy是一个异步处理框架,是纯Python实现的爬虫框架,其架构清晰,模块之间的耦合程度低,可拓展性强,可以灵活完成各种需求.我们只需要定制几个模块就可以轻松实现一个爬虫. 1.架构  Scra ...

  8. rest framwork 小试身手

    models.py from django.db import models class Course(models.Model): """ 课程表 "&quo ...

  9. Docker bridge br0 pipework

    Docker Centos7 下建立 Docker 桥接网络 - weifengCorp - 博客园https://www.cnblogs.com/weifeng1463/p/7468497.html ...

  10. Linux 文件特殊权限 SUID SGID SBIT

    文件除了常规的权限r, w, x 还有一些特殊的权限,s与t权限,具体的用处如下 1 SetUID 当s 这个标志出现在文件所有者的x权限上时, 例如/usr/bin/passwd, [root@or ...