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\)都有些什么神仙题 然 ...
随机推荐
- 多路选择器实现总线结构——Verilog
////////////////////////////////////////////////////////////////////////////////// //该程序完成通过多路选择器MUX ...
- rest-framework解析器,url控制,分页,响应器,渲染器,版本控制
解析器 1.json解析器 发一个json格式的post请求.后台打印: request_data---> {'title': '北京折叠'} request.POST---> <Q ...
- 持续集成之Jenkins自动部署war包到远程服务器
一.无war包链接的情况 无war包链接时,需先下载war包到本地,然后执行: ---------------------------------------------以下部分为转载-------- ...
- agora入门案例
一,下载agora的WebSDK 二,运行index.html 三,输入appID 1.找到appID 2.页面输入appID,查看效果
- 使用log4j记录日志
目录 log4j的优点 导入log4j的jar包 log4j的错误级别 log4j日志的输出目的地 log4j的配置示例 log4j的全局配置讲解 控制台日志的配置讲解 日志输出文件的配置讲解 使用l ...
- WPF中任务栏只显示主窗口
我们在用WPF开发的时候,常常会遇到在主窗口打开的情况下,去显示子窗口,而此时任务栏同时显示主窗口与子窗口.这样看起来很不美观.所以在弹出子窗口之前,设置它的几个相应属性,便不会出现这种问题了. // ...
- Effective C++目录
条款1:视C++为一个语言联邦 条款2:尽量以const.enum.inline替换#define 条款3:尽可能使用const 条款4:确定对象使用前已先被初始化 条款5:了解C++默认编写并调用哪 ...
- 1065. 我的日程安排表 I
描述 实现MyCalendar类来存储您的活动. 如果新添加的活动没有重复,则可以添加. 你的类将有方法book(int start,int end). 这代表左闭右开的间隔[start,end)有了 ...
- Eclipse打开java文件繁体字
右键-->properties-->Resource-->Text file encoding, 改成utf-8 .
- .Net在操作mysql查询的时候出现“: Unknown column 'UserName' in 'where clause'”错误
今天使用.Net操作mysql查询的时候,如果加上条件查询的时候就会出现 Unknown column 'UserName' in 'where clause'这个错,不加条件直接select * f ...