Luogu 4492 [HAOI2018]苹果树 组合数

https://www.luogu.org/problemnew/show/P4492

找每个编号的点的父边的贡献,组合数和阶乘就能算了。

我考场上怎么就是没想到呢。

调了好久好久好久好久调不出来,样例一直过不了,刚刚发现是溢出了,我是个zz。

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<algorithm>
 4 #include<cmath>
 5 #include<iostream>
 6 using namespace std;
 7 #define LL long long
 8 LL n;LL p;
 9 LL f[2010][2010]={};
10 LL zu[2010][2010]={};
11 LL t[2010]={};
12 int main(){
13     scanf("%lld%lld",&n,&p);
14     LL ans=0; zu[0][0]=1; t[0]=1;
15     for(LL i=1;i<=n;i++)t[i]=(t[i-1]*i)%p;
16     for(LL i=1;i<=n;i++){
17         zu[i][0]=1;
18         for(LL j=1;j<=i;j++)zu[i][j]=(zu[i-1][j]+zu[i-1][j-1])%p;
19     }
20     for(LL i=1;i<=n;i++){
21         f[i][0]=1;
22         for(int j=1;j<=n;j++){
23             f[i][j]=(f[i][j-1]*(i+j-1))%p;
24         }
25     }
26     for(LL i=2;i<=n;i++){
27         for(LL j=n-i+1;j>0;j--){
28             LL w=(zu[n-i][j-1]*t[j])%p;
29             w=(w*((t[i]*f[i-1][n-i-j+1])%p))%p;
30             w=(w*((j*(n-j))%p))%p;
31             ans=(ans+w)%p;
32         }
33     }
34     printf("%lld\n",ans);
35     return 0;
36 }

原文地址:https://www.cnblogs.com/137shoebills/p/9095553.html

时间: 2024-11-13 16:19:14

Luogu 4492 [HAOI2018]苹果树 组合数的相关文章

[HAOI2018]苹果树

题目描述 小 C 在自己家的花园里种了一棵苹果树, 树上每个结点都有恰好两个分支. 经过细心的观察, 小 C 发现每一天这棵树都会生长出一个新的结点. 第一天的时候, 果树会长出一个根结点, 以后每一天, 果树会随机选择一个当前树中没有长出过结点 的分支, 然后在这个分支上长出一个新结点, 新结点与分支所属的结点之间连接上一条边. 小 C 定义一棵果树的不便度为树上两两结点之间的距离之和, 两个结点之间 的距离定义为从一个点走到另一个点的路径经过的边数. 现在他非常好奇, 如果 NNN 天之后小

luogu P4491 [HAOI2018]染色

传送门 这一类题都要考虑推式子 首先推出题目要求的式子,枚举正好有\(s\)个颜色的种类(范围\([0,p=min(\lfloor\frac{n}{s}\rfloor,m)]\)),然后对于后面的颜色可能也有数量为\(s\)的,容斥一下即可,即\[ans=\sum_{k=0}^{p}w_k*\binom{m}{k}*\binom{n}{ks}*\frac{(ks)!}{(s!)^k}\sum_{i=0}^{p-k}(-1)^i*\binom{m-k}{i}*\binom{n-ks}{is}*\f

bzoj 5305 [Haoi2018] 苹果树

传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=5305 [题解] 1 # include <bits/stdc++.h> 2 using namespace std; 3 4 const int M = 2010; 5 6 int n, mod; 7 int C[M][M], fac[M]; 8 9 int main() { 10 cin >> n >> mod; 11 fac[0] = 1; 12 for (

HAOI2018苹果树

题解 首先所有生成树的情况树是\(n!\)的,因为第一次有1中方法,第二次有两种放法,以此类推... 然后我们发现距离这种东西可以直接枚举每条边算贡献. 于是我们枚举了一个点\(i\),又枚举了这个点的子树大小\(size\),那么这部分的距离也就可以直接算出来了. \[ (n-size)*size \] 接下来我们还要去算有多少种方案. 对于子树内部,标号和排列方法都没有确定,所以方案数就是: \[ \binom{n-i}{size}*size! \] 然后考虑子树外的情况,首先子树外的点不可

浴谷夏令营题单

这是群里一位神犇整理的,我只负责将它们做完. 一.暴力.搜索Luogu 1588 丢失的牛Luogu 1463 [SDOI2005]反素数antBzoj 1085 [SCOI2005]骑士精神Luogu 1019 单词接龙Luogu 1078 文化之旅Luogu 1312 Mayan游戏Luogu 3823 蚯蚓排队Codeforces 444B Codeforces 555DLuogu 1979 华容道 二.初等数论Poj 3292 H合成数Luogu 1890 gcd区间Luogu 1029

MZOJ 1134 &amp;&amp; LuoGu P2015 二叉苹果树

MZOJ 1134 && LuoGu P2015 二叉苹果树     [传送门] #include<bits/stdc++.h> using namespace std; const int maxn=500; int N,Q; int head[maxn],k=0; int w[maxn][maxn],f[maxn][maxn]; struct edge{ int v,w,nxt; }e[maxn<<1]; void init(){ freopen("i

luogu P2015 二叉苹果树

P2015 二叉苹果树 题目描述 有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点) 这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1. 我们用一根树枝两端连接的结点的编号来描述一根树枝的位置.下面是一颗有4个树枝的树 2        5 \     / 3   4 \ / 1 现在这颗树枝条太多了,需要剪枝.但是一些树枝上长有苹果. 给定需要保留的树枝数量,求出最多能留住多少苹果. 输入输出格式 输入格式: 第1行2个数,N和Q(1<=Q<

HAOI2018 [HAOI2018]染色 【组合数 + 容斥 + NTT】

题目 为了报答小 C 的苹果, 小 G 打算送给热爱美术的小 C 一块画布, 这块画布可 以抽象为一个长度为 \(N\) 的序列, 每个位置都可以被染成 \(M\) 种颜色中的某一种. 然而小 C 只关心序列的 \(N\) 个位置中出现次数恰好为 \(S\) 的颜色种数, 如果恰 好出现了 \(S\) 次的颜色有 \(K\) 种, 则小 C 会产生 \(W_k\) 的愉悦度. 小 C 希望知道对于所有可能的染色方案, 他能获得的愉悦度的和对 1004535809 取模的结果是多少. 输入格式 从

Luogu P2822 组合数问题(前缀和)

P2822 组合数问题 题意 题目描述 组合数\(C_n^m\)表示的是从\(n\)个物品中选出\(m\)个物品的方案数.举个例子,从\((1,2,3)\)三个物品中选择两个物品可以有\((1,2),(1,3),(2,3)\)这三种选择方法.根据组合数的定义,我们可以给出计算组合数\(C_n^m\)的一般公式: \[C_n^m=\frac{n!}{m!(n-m)!}\] 其中\(n!=1\times 2\times \cdots \times n\):特别地,定义\(0!=1\). 小葱想知道如