分析

 代码

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int mod = ;
const int g = ;
int p[],inv[],G,cc[][],a[],b[],c[],d[],r[];
inline int pw(int x,int p){
int res=;
while(p){
if(p&)res=1ll*res*x%mod;
x=1ll*x*x%mod;
p>>=;
}
return res;
}
inline void ntt(int a[],int n,int f){
int i,j,k,now;
for(i=;i<n;i++)if(i<r[i])swap(a[i],a[r[i]]);
for(k=;k<n;k<<=){
if(f==)now=g;
else now=G;
int wn=pw(now,(mod-)/(k<<));
for(i=;i<n;i+=(k<<)){
int w=,p,q;
for(j=;j<k;j++,w=1ll*w*wn%mod){
p=a[i+j],q=1ll*a[i+j+k]*w%mod;
a[i+j]=(p+q)%mod;
a[i+j+k]=(p-q+mod)%mod;
}
}
}
}
inline int get_sum(int n,int A,int B,int C,int D){
int i,j,k,m=,len=;
if(n>A+B+C+D||n<)return ;
while(m<((A+B+C+D)<<))m<<=,len++;
for(i=;i<m;i++)r[i]=((r[i>>]>>)|((i&)<<(len-)));
for(i=;i<m;i++)a[i]=(i<=A)?inv[i]:;
for(i=;i<m;i++)b[i]=(i<=B)?inv[i]:;
for(i=;i<m;i++)c[i]=(i<=C)?inv[i]:;
for(i=;i<m;i++)d[i]=(i<=D)?inv[i]:;
ntt(a,m,),ntt(b,m,),ntt(c,m,),ntt(d,m,);
for(i=;i<m;i++)a[i]=1ll*a[i]*b[i]%mod*c[i]%mod*d[i]%mod;
ntt(a,m,-);
return 1ll*p[n]*a[n]%mod*pw(m,mod-)%mod;
}
signed main(){
int n,A,B,C,D,i,j,k;
G=pw(g,mod-);
p[]=;
for(i=;i<=;i++)p[i]=1ll*p[i-]*i%mod;
inv[]=pw(p[],mod-);
for(i=;i>=;i--)inv[i]=1ll*inv[i+]*(i+)%mod;
for(i=;i<=;i++)cc[i][]=cc[i][i]=;
for(i=;i<=;i++)
for(j=;j<i;j++)cc[i][j]=(cc[i-][j]+cc[i-][j-])%mod;
scanf("%lld%lld%lld%lld%lld",&n,&A,&B,&C,&D);
int Ans=;
for(i=;i<=n/;i++){
int res=(i&)?-:;
res*=cc[n-*i][i];
res=1ll*res*get_sum(n-*i,A-i,B-i,C-i,D-i)%mod;
Ans=(Ans+res+mod)%mod;
}
printf("%lld\n",Ans);
return ;
}

p5339 [TJOI2019]唱、跳、rap和篮球的更多相关文章

  1. [bzoj5510]唱跳rap和篮球

    显然答案可以理解为有(不是仅有)0对情况-1对情况+2对情况-- 考虑这个怎么计算,先计算这t对情况的位置,有c(n-3t,t)种情况(可以理解为将这4个点缩为1个,然后再从中选t个位置),然后相当于 ...

  2. 【题解】Luogu P5339 [TJOI2019]唱、跳、rap和篮球

    原题传送门 这题zsy写的是\(O(n^2)\),还有NTT\(O(n^2\log n)\)的做法.我的是暴力,\(O(\frac{a b n}{4})\),足够通过 考虑设\(f(i)\)表示序列中 ...

  3. Luogu P5339 [TJOI2019]唱、跳、rap和篮球

    题目 设\(f_i\)表示从\((a-4i,b-4i,c-4i,d-4i)\)中选\(n-4i\)个排队的方案数. 那么我们可以容斥,答案为\(\sum\limits_{i=0}^{lim}(-1)^ ...

  4. 将Android手机无线连接到Ubuntu实现唱跳Rap

    您想要将Android设备连接到Ubuntu以传输文件.查看Android通知.以及从Ubuntu桌面发送短信 – 你会怎么做?将文件从手机传输到PC时不要打电话给自己:使用GSConnect就可以. ...

  5. [TJOI2019]唱、跳、rap和篮球_生成函数_容斥原理_ntt

    [TJOI2019]唱.跳.rap和篮球 这么多人过没人写题解啊 那我就随便说说了嗷 这题第一步挺套路的,就是题目要求不能存在balabala的时候考虑正难则反,要求必须存在的方案数然后用总数减,往往 ...

  6. [TJOI2019]唱、跳、rap和篮球——NTT+生成函数+容斥

    题目链接: [TJOI2019]唱.跳.rap和篮球 直接求不好求,我们考虑容斥,求出至少有$i$个聚集区间的方案数$ans_{i}$,那么最终答案就是$\sum\limits_{i=0}^{n}(- ...

  7. [luogu5339] [TJOI2019]唱、跳、rap和篮球(容斥原理+组合数学)(不用NTT)

    [luogu5339] [TJOI2019]唱.跳.rap和篮球(容斥原理+组合数学)(不用NTT) 题面 略 分析 首先考虑容斥,求出有i堆人讨论的方案. 可以用捆绑法,把每堆4个人捆绑成一组,其他 ...

  8. 「TJOI2019」唱、跳、rap 和篮球 题解

    题意就不用讲了吧-- 鸡你太美!!! 题意: 有 \(4\) 种喜好不同的人,分别最爱唱.跳. \(rap\).篮球,他们个数分别为 \(A,B,C,D\) ,现从他们中挑选出 \(n\) 个人并进行 ...

  9. [TJOI2019]唱,跳,rap,篮球(生成函数,组合数学,NTT)

    算是补了个万年大坑了吧. 根据 wwj 的题解(最准确),设一个方案 \(S\)(不一定合法)的鸡你太美组数为 \(w(S)\). 答案就是 \(\sum\limits_{S}[w(S)=0]\). ...

随机推荐

  1. 浅谈vue父子组件之间的传值

    前言:本章主要说下父子组件的传值,为商品列表组件之间的传值做一个基础预热.Github:https://github.com/Ewall1106/mall(请选择分支chapter23) 1.父组件向 ...

  2. DataTable clone()和copy()的区别

    clone()只是复制表结构 copy()是深度复制,表结构和数据

  3. 前端 CSS的选择器 属性选择器

    属性选择器,字面意思就是根据标签中的属性,选中当前的标签. 属性选择器 通常在表单控件中 使用比较多 根据属性查找 /*用于选取带有指定属性的元素.*/ <!DOCTYPE html> & ...

  4. loading 加载工具

    loading 加载工具:http://loading.awesomes.cn/

  5. [hdu6558][CCPC2018吉林D题]The Moon(期望dp)

    题目链接 当时年少不懂期望$dp$,时隔一年看到这道题感觉好容易.... 定义状态$dp[i]$表示当前的$q$值为$i$时的期望,则当$q$值为$100$时$dp[100]=100/q$,这时后发现 ...

  6. [BZOJ4182]Shopping (点分治+树上多重背包+单调队列优化)

    [BZOJ4182]Shopping (点分治+树上多重背包+单调队列优化) 题面 马上就是小苗的生日了,为了给小苗准备礼物,小葱兴冲冲地来到了商店街.商店街有n个商店,并且它们之间的道路构成了一颗树 ...

  7. 垂直口风琴菜单3(jquery)

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. Android客户端与Python服务器端通信之上传图片

    继上篇成功的与服务器端通信上之后,我现在需要将安卓本地的图片上传到服务端.服务端接收图片存下来. 参考:https://blog.csdn.net/qq_26906345/article/detail ...

  9. pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库。

    SYNOPSIS pg_restore [ option...] [ filename] DESCRIPTION 描述 pg_restore 是一种用于恢复由 pg_dump(1) 创建的任何非纯文本 ...

  10. MYSQL学习笔记——数据类型

    mysql的数据类型可以分为三大类,分别是数值数据类型.字符串数据类型以及日期时间数据类型. 数值数据类型                                               ...