p5339 [TJOI2019]唱、跳、rap和篮球
分析


代码
#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和篮球的更多相关文章
- [bzoj5510]唱跳rap和篮球
显然答案可以理解为有(不是仅有)0对情况-1对情况+2对情况-- 考虑这个怎么计算,先计算这t对情况的位置,有c(n-3t,t)种情况(可以理解为将这4个点缩为1个,然后再从中选t个位置),然后相当于 ...
- 【题解】Luogu P5339 [TJOI2019]唱、跳、rap和篮球
原题传送门 这题zsy写的是\(O(n^2)\),还有NTT\(O(n^2\log n)\)的做法.我的是暴力,\(O(\frac{a b n}{4})\),足够通过 考虑设\(f(i)\)表示序列中 ...
- Luogu P5339 [TJOI2019]唱、跳、rap和篮球
题目 设\(f_i\)表示从\((a-4i,b-4i,c-4i,d-4i)\)中选\(n-4i\)个排队的方案数. 那么我们可以容斥,答案为\(\sum\limits_{i=0}^{lim}(-1)^ ...
- 将Android手机无线连接到Ubuntu实现唱跳Rap
您想要将Android设备连接到Ubuntu以传输文件.查看Android通知.以及从Ubuntu桌面发送短信 – 你会怎么做?将文件从手机传输到PC时不要打电话给自己:使用GSConnect就可以. ...
- [TJOI2019]唱、跳、rap和篮球_生成函数_容斥原理_ntt
[TJOI2019]唱.跳.rap和篮球 这么多人过没人写题解啊 那我就随便说说了嗷 这题第一步挺套路的,就是题目要求不能存在balabala的时候考虑正难则反,要求必须存在的方案数然后用总数减,往往 ...
- [TJOI2019]唱、跳、rap和篮球——NTT+生成函数+容斥
题目链接: [TJOI2019]唱.跳.rap和篮球 直接求不好求,我们考虑容斥,求出至少有$i$个聚集区间的方案数$ans_{i}$,那么最终答案就是$\sum\limits_{i=0}^{n}(- ...
- [luogu5339] [TJOI2019]唱、跳、rap和篮球(容斥原理+组合数学)(不用NTT)
[luogu5339] [TJOI2019]唱.跳.rap和篮球(容斥原理+组合数学)(不用NTT) 题面 略 分析 首先考虑容斥,求出有i堆人讨论的方案. 可以用捆绑法,把每堆4个人捆绑成一组,其他 ...
- 「TJOI2019」唱、跳、rap 和篮球 题解
题意就不用讲了吧-- 鸡你太美!!! 题意: 有 \(4\) 种喜好不同的人,分别最爱唱.跳. \(rap\).篮球,他们个数分别为 \(A,B,C,D\) ,现从他们中挑选出 \(n\) 个人并进行 ...
- [TJOI2019]唱,跳,rap,篮球(生成函数,组合数学,NTT)
算是补了个万年大坑了吧. 根据 wwj 的题解(最准确),设一个方案 \(S\)(不一定合法)的鸡你太美组数为 \(w(S)\). 答案就是 \(\sum\limits_{S}[w(S)=0]\). ...
随机推荐
- 深度探索区块链/基于Gossip的P2P数据分发(4)
一.概述 背书节点模拟执行签名的结果会经过排序服务(Ording service)广播给所有的节点. 它提供的是一种原子广播服务(Atomic Broadcast),即在逻辑上所有节点接收到的消息顺序 ...
- 前端 CSS 盒子模型
盒模型的概念 在CSS中,"box model"这一术语是用来设计和布局时使用,然后在网页中基本上都会显示一些方方正正的盒子.我们称为这种盒子叫盒模型. 盒模型有两种:标准模型和I ...
- python基础-8迭代器(iter)和生成器(yield)
一 生成器 从Python2.2起,生成器提供了一种简洁的方式帮助返回列表元素的函数来完成简单和有效的代码. 它基于yield指令,允许停止函数并立即返回结果.此函数保存其执行上下文,如果需要,可立即 ...
- python Calendar 模块导入及用法
Calendar 是python 日历模块,此模块的函数都是日历相关的,例如打印某月的字符月历,星期之类的模块,下面剖析python Calendar 模块导入及用法. 1,python导入日历模块 ...
- 你浏览器的书签栏还够用么? - 程序员学点xx 特辑
lluxury 运维开发时间 为什么会想到这个话题,是因为最近看到的一条广告:注册 xx 送2048GB资料.yann 暗自感慨:"都9012年了,还有人分享家里的祖传硬盘".2T ...
- Windows 进入上帝模式窗口
Win10上帝模式如何启用? 默认情况下,Win10的上帝模式是隐藏的,如果要开启的话,操作步骤也非常简单,下面就介绍两种方法. 方法一.直接运行命令行 1.使用[Win + R ]快捷键打开“运行” ...
- Linux下NFS服务器的搭建与配置(转)
一.NFS服务简介 NFS 就是 Network FileSystem 的缩写,最早之前是由sun 这家公司所发展出来的. 它最大的功能就是可以透过网络,让不同的机器.不同的操作系统.可以彼此分享个别 ...
- chattr 改变文件的扩展属性
1. 命令功能 chattr和lsattr用来改变文件.目录属性和查看这种文件属性:chmod只是改变文件的读.写.执行权限,更底层的属性控制是由chattr来改变. 2. 语法格式 chattr [ ...
- openGL如何在改变窗口大小时,使自己的图形不被拉伸
这里要注意两个概念:视口和视景体,当视口的纵横比和视景体的纵横比相同的时候,改变窗口大小,图像才不会变形: 视景体是指成像景物所在空间的集合.它是一个空间集合体. 单个的视景体,比如一个球体,若要完全 ...
- K8S进入容器方法
前言 k8s如何进入一个pod里有多个容器的方法 参考地址 https://blog.csdn.net/aa1215018028/article/details/81205691 方法1 kubect ...