LOJ6436 [PKUSC2018] 神仙的游戏 【FFT】
题目分析:
题目要求前后缀相同,把串反过来之后是一个很明显的卷积的形式。这样我们可以完成初步判断(即可以知道哪些必然不行)。
然后考虑一下虽然卷积结果成立,但是存在问号冲突的情况。

箭头之间应当不存在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】的更多相关文章
- [LOJ6436][PKUSC2018]神仙的游戏
loj description 给你一个只有01和?的字符串,问你是否存在一种把?改成01的方案使串存在一个长度为\(1-n\)的\(border\).\(n\le5\times10^5\) sol ...
- [PKUSC2018]神仙的游戏(FFT)
给定一个01?串,对所有len询问是否存在一种填法使存在长度为len的border. 首先有个套路的性质:对于一个长度为len的border,这个字符串一定有长度为n-len的循环节(最后可以不完整) ...
- BZOJ5372: [Pkusc2018]神仙的游戏
BZOJ5372: [Pkusc2018]神仙的游戏 https://lydsy.com/JudgeOnline/problem.php?id=5372 分析: 如果\(len\)为\(border\ ...
- BZOJ5372: PKUSC2018神仙的游戏
传送门 Sol 自己还是太 \(naive\) 了,上来就构造多项式和通配符直接匹配,然后遇到 \(border\) 相交的时候就 \(gg\) 了 神仙的游戏蒟蒻还是玩不来 一个小小的性质: 存在长 ...
- bzoj 5372: [Pkusc2018]神仙的游戏
Description 小D和小H是两位神仙.他们经常在一起玩神仙才会玩的一些游戏,比如"口算一个4位数是不是完全平方数". 今天他们发现了一种新的游戏:首先称s长度为len的前缀 ...
- loj 6436 PKUSC2018 神仙的游戏
传送门 好妙蛙 即串\(s\)长度为\(n\)首先考虑如果一个长度为\(len\)的\(border\)存在,当且仅当对所有\(i\in[1,len],s[i]=s[n-len+i]\),也就是所有模 ...
- [PKUSC2018]神仙的游戏
题目 画一画就会发现一些奇诡的性质 首先如果\(len\)为一个\(\operatorname{border}\),那么必然对于\(\forall i\in [1,len]\),都会有\(s_i=s_ ...
- BZOJ5372 PKUSC2018神仙的游戏(NTT)
首先有一个想法,翻转串后直接卷积看有没有0匹配上1.但这是必要而不充分的因为在原串和翻转串中?不能同时取两个值. 先有一些结论: 如果s中长度为len的前缀是border,那么其存在|s|-len的循 ...
- 【LOJ6436】【PKUSC2018】神仙的游戏(NTT)
[LOJ6436][PKUSC2018]神仙的游戏(NTT) 题面 LOJ 题解 看到\(zsy\)从\(PKUSC\)回来就秒掉了这种神仙题 吓得我也赶快看了看\(PKUSC\)都有些什么神仙题 然 ...
随机推荐
- Quartz.NET 任务调度新教程
https://www.cnblogs.com/yscit/p/10393867.html
- 对Vuejs框架原理名词解读
渐进式()+虚拟Dom: vue-cli 遍历Dom:先序遍历DOM树的5种方法! 三层架构+m v c +mvp+m v vm()+MVC,MVP 和 MVVM 的图示 剖析vue MVVM实现原理 ...
- Linux登录MySQL时出现 Can't connect to local MySQL server through socket '/tmp/mysql.sock'解决方法
在Linux上登录MySQL时出现如下提示,如下图: 通过查找资料了解到: MySQL有两种连接方式: (1)TCP/IP (2)socket 对mysql.sock来说,其作用是程序与mysqlse ...
- Python_面向对象_单例模式
class A(object): pass a1 = A() a2 = A() print(a1 == a2)print(id(a1))print(id(a2)) 结果: False 23257231 ...
- Django的contenttypes
这是一个django内置的表结构,为的就是通过两个字段让表和N张表创建FK关系. 比如说有两种不同课程,这两种课程都有价格周期和策略.如果最低级的则是给每个表创建一个价格策略.如果非要在同一个表内使用 ...
- Java Core - Class文件结构之魔数、版本号、常量池
下图是一个.java文件被编译器编译后产生的二进制的class文件的内容:由图可知,class文件是用两位16进制数来表示的一个字节. 1个字节就是1Byte,1Byte=8bit. 一.魔数(CAF ...
- 转:VIM选择文本块/复制/粘贴
VIM选择文本块/复制/粘贴 - lcj_cjfykx的专栏 - CSDN博客https://blog.csdn.net/lcj_cjfykx/article/details/9091569
- gethostbyname用法
//会优先查询解析%windir%\system32\drivers\etc\hosts中静态dns表 //一个域名可对应多个IP hostent->h_addr_list ==> 是in ...
- IdentityServer4【Introduction】之概括
The Big Picture 大多数现代应用看起来都像下面的样子: 大多数的交互是下面这样: 浏览器与web应用之间的通信 web应用和web APIs之间的通信(这两者有时是独立的,有时是有用户参 ...
- javascript博客爱心特效代码与代码解析
这个鼠标点击出现爱心的特效经常在别的博客里见到,于是我查了度娘后拿来直接用上了. 虽然不知道原作者是谁,但肯定是个大神,只有通过观摩他/她的代码膜拜一下啦. 直接上代码(解析在代码注释里): // 自 ...