FWT模板

代码来自51nod1570

#include<cstdio>
#include<cstring>
#include<algorithm>
#define MN 501
using namespace std;

int read_p,read_ca;
inline int read(){
    read_p=0;read_ca=getchar();
    while(read_ca<‘0‘||read_ca>‘9‘) read_ca=getchar();
    while(read_ca>=‘0‘&&read_ca<=‘9‘) read_p=read_p*10+read_ca-48,read_ca=getchar();
    return read_p;
}
const int MOD=1e9+7,N2=(MOD+1)/2;
int n,m,MMH=0,Mavis=0,_Mavis=0,mmh[MN][(1<<16)+1],ro,num=0,a[(1<<16)+1],b[(1<<16)+1];
char s[MN];
inline void M(int &x){while(x>=MOD)x-=MOD;while(x<0)x+=MOD;}
void work(int p,bool b,int mmh[]){
    int s=0;
    for (int i=0;i<16;i++) s|=(((i>>p)&1)^b)<<i;
    mmh[s]++;
}
inline void FWT_x(int N,int a[]){
    for (int i=2;i<=N;i<<=1)
    for (int m=i>>1,j=0;j<N;j+=i)
    for (int k=0;k<m;k++) M(a[j+k]+=a[j+k+m]),M(a[j+k+m]=a[j+k]-2*a[j+k+m]);
}
inline void IFWT_x(int N,int a[]){
    for (int i=2;i<=N;i<<=1)
    for (int m=i>>1,j=0;j<N;j+=i)
    for (int k=0;k<m;k++){
        int A=a[j+k],B=a[j+k+m];
        a[j+k]=1LL*(A+B)*N2%MOD;
        a[j+k+m]=1LL*(A+MOD-B)*N2%MOD;
    }
}
inline void FWT_a(int N,int a[]){
    for (int i=2;i<=N;i<<=1)
    for (int m=i>>1,j=0;j<N;j+=i)
    for (int k=0;k<m;k++) M(a[j+k]+=a[j+k+m]);
}
inline void IFWT_a(int N,int a[]){
    for (int i=2;i<=N;i<<=1)
    for (int m=i>>1,j=0;j<N;j+=i)
    for (int k=0;k<m;k++) M(a[j+k]-=a[j+k+m]);
}
inline void FWT_o(int N,int a[]){
    for (int i=2;i<=N;i<<=1)
    for (int m=i>>1,j=0;j<N;j+=i)
    for (int k=0;k<m;k++) M(a[j+k+m]+=a[j+k]);
}
inline void IFWT_o(int N,int a[]){
    for (int i=2;i<=N;i<<=1)
    for (int m=i>>1,j=0;j<N;j+=i)
    for (int k=0;k<m;k++) M(a[j+k+m]-=a[j+k]);
}
void hb(int A[],int B[],int mmh[],bool kind){
    for (int i=0;i<(1<<16);i++) a[i]=A[i],b[i]=B[i];
    if (kind){
        FWT_o(1<<16,a);FWT_o(1<<16,b);
        for (int i=0;i<(1<<16);i++) a[i]=1LL*a[i]*b[i]%MOD;
        IFWT_o(1<<16,a);
        for (int i=0;i<(1<<16);i++) M(mmh[i]+=a[i]);
    }else{
        FWT_a(1<<16,a);FWT_a(1<<16,b);
        for (int i=0;i<(1<<16);i++) a[i]=1LL*a[i]*b[i]%MOD;
        IFWT_a(1<<16,a);
        for (int i=0;i<(1<<16);i++) M(mmh[i]+=a[i]);
    }
}
int work(int l,int r){
    int p=++num,i,j;
    if (l==r){
        if (s[l]==‘?‘) for (i=0;i<4;i++) work(i,0,mmh[p]),work(i,1,mmh[p]);else
        if (s[l]==‘A‘) work(0,0,mmh[p]);else
        if (s[l]==‘a‘) work(0,1,mmh[p]);else
        if (s[l]==‘B‘) work(1,0,mmh[p]);else
        if (s[l]==‘b‘) work(1,1,mmh[p]);else
        if (s[l]==‘C‘) work(2,0,mmh[p]);else
        if (s[l]==‘c‘) work(2,1,mmh[p]);else
        if (s[l]==‘D‘) work(3,0,mmh[p]);else
        if (s[l]==‘d‘) work(3,1,mmh[p]);
    }else{
        for (i=l,j=0;;i++)
        if (j+=s[i]==‘(‘,j-=s[i]==‘)‘,!j) break;
        i++;
        int L=work(l+1,i-2),R=work(i+2,r-1);
        if (s[i]==‘&‘) hb(mmh[L],mmh[R],mmh[p],0);else
        if (s[i]==‘|‘) hb(mmh[L],mmh[R],mmh[p],1);else
        hb(mmh[L],mmh[R],mmh[p],0),hb(mmh[L],mmh[R],mmh[p],1);
    }
    return p;
}
int main(){
    scanf("%s",s);
    ro=work(0,strlen(s)-1);
    n=read();
    for (int i=1;i<=n;i++){
        int a=0;
        a|=read();a|=read()<<1;a|=read()<<2;a|=read()<<3;
        MMH|=1<<a;Mavis|=read()<<a;
    }
    for (int i=0;i<(1<<16);i++)
    if (!((i^Mavis)&MMH)) (_Mavis+=mmh[ro][i])%=MOD;
    printf("%d\n",_Mavis);
}

时间: 2024-10-23 10:41:46

FWT模板的相关文章

FWT

FWT模板: 1 void FWT(int a[],int n) 2 { 3 for(int d=1;d<n;d<<=1) //你甚至可以RANDOMSHUFFLE 4 for(int m=d<<1,i=0;i<n;i+=m) 5 for(int j=0;j<d;j++) 6 { 7 int x=a[i+j],y=a[i+j+d]; 8 a[i+j]=(x+y)%mod,a[i+j+d]=(x-y+mod)%mod; 9 //xor:a[i+j]=x+y,a[i+

bzoj 4589: Hard Nim

传送门 先筛出m以内的质数,g[i]表示i是否是素数 f[i][j]表示前n堆数异或和为j的方案数. f[0][0]=1; f[0][1]~f[0][m]=0; f[i][j] = sigma( f[i-1][k] * g[k^j] ) 发现这个玩意满足乘法结合律 ∴ f[n][] = sigma(f[0][]*g[]*g[]*g[]*g[]--) =sigma(f[0]*g[]^n) ; f[0][]为单位元 所以ans=g[]^n g[]^n可以用FWT+快速幂来算,时间复杂度就是log^2

Vue.js项目模板搭建

前言 从今年(2017年)年初起,我们团队开始引入「Vue.js」开发移动端的产品.作为团队的领头人,我的首要任务就是设计 整体的架构 .一个良好的架构必定是具备丰富的开发经验后才能搭建出来的.虽然我有多年的前端开发经验,但就「Vue.js」来说,仍然是个新手.所幸「Vue.js」有一个配套工具「Vue-CLI」,它提供了一些比较成熟的项目模板,很大程度上降低了上手的难度.然而,很多具体的问题还是要自己思考和解决的. 项目划分 我们公司的H5产品大部分是嵌套在手机客户端里面的页面.每个项目的功能

ac自动机基础模板(hdu2222)

In the modern time, Search engine came into the life of everybody like Google, Baidu, etc. Wiskey also wants to bring this feature to his image retrieval system. Every image have a long description, when users type some keywords to find the image, th

hdu 2966 In case of failure kdtree模板题

问求每个点距离平方的最小的点 kd-tree模板题…… 1 #include<bits/stdc++.h> 2 #define cl(a,b) memset(a,b,sizeof(a)) 3 #define debug(x) cerr<<#x<<"=="<<(x)<<endl 4 using namespace std; 5 typedef long long ll; 6 typedef pair<int,int>

eclipse添加xml模板

//因为学javaee,中框架,,感觉配置文件好多, window-preferences-xml-xmlfiles-editor-templates-选中模板,-edit

POJ3528 HDU3662 三维凸包模板

POJ3528 HDU3662 第一道题 给定若干点 求凸包的表面积,第二题 给定若干点就凸包的面数. 简单说一下三维凸包的求法,首先对于4个点假设不共面,确定了唯一四面体,对于一个新的点,若它不在四面体内,为了让它进入凸包, 则对于所有凸包上的边,若边的一面是该点可以看到的而另一面看不到,则该点与该边构成的面要加入凸包. 模板代码非常清晰, #include<stdio.h> #include<algorithm> #include<string.h> #includ

zabbix用自带的模板监控mysql

先看一下zabbix自带的mysql模板监控项: #很少是吧,没事生产环境一般我们不用,下一篇将介绍生产环境用的另一种mysql监控. 配置zabbix自带的模板监控mysql数据库:

小程序砸金蛋、外卖模板上线啦,快到酷客多商户后台更新!

最近,微信小程序官方发文不断,又开放十几项接口,逐步给企业主带来跟多福利.于此同时,酷客多研发团队也保持着一贯的研发和版本迭代速度,此次版本主要新增幸运砸金蛋.外卖模板.意见反馈三个模块 1.新增幸运砸金蛋,大奖中不停 通过此功能可增加平台趣味性,增强用户粘性,刺激用户二次消费,是与用户互动的一大利器. 2新增外卖模板,外卖送起来 此模板是餐饮企业的福利,可在注册或者酷客多商户管理后台直接选择此模板,瞬间让您的小程序首页变的高大上,从此再也不用担心第三方外卖平台高额的佣金和账期了,因为酷客多只提