BZOJ 1005: [HNOI2008]明明的烦恼 Purfer序列 大数

时间:2023-12-21 11:33:26

1005: [HNOI2008]明明的烦恼

Time Limit: 20 Sec

Memory Limit: 256 MB

题目连接

http://www.lydsy.com/JudgeOnline/problem.php?id=1005

Description

自从明明学了树的结构,就对奇怪的树产生了兴趣...... 给出标号为1到N的点,以及某些点最终的度数,允许在任意两点间连线,可产生多少棵度数满足要求的树?

Input

第一行为N(0 < N < = 1000),接下来N行,第i+1行给出第i个节点的度数Di,如果对度数不要求,则输入-1

Output

一个整数,表示不同的满足要求的树的个数,无解输出0

Sample Input

3
1
-1
-1

Sample Output

2

HINT

题意

题解

实际上就是让你求,有多少种Purfer序列

理解Purfer序列之后,这就是排列组合题了

这篇博文写的非常精彩:http://www.cnblogs.com/zhj5chengfeng/archive/2013/08/23/3278557.html

代码:

import java.util.*;
import java.math.*; public class Main {
static int n, d[]=new int[];
static BigInteger p[]=new BigInteger[];
static BigInteger ans; static public void main(String args[]) {
Scanner IN=new Scanner(System.in);
n=IN.nextInt();
int sum=, flag=, cnt=;
for(int i=; i<n; i++) {
d[i]=IN.nextInt();
if(d[i]== || d[i]>n-) flag=;
if(d[i]==-) continue;
sum+=d[i]-;
cnt++;
}
IN.close();
if(n==) {
if(d[]== || d[]==-) System.out.println();
else System.out.println();
return;
}
if(n==) {
if((d[]==- || d[]==) && (d[]==- || d[]==-)) System.out.println();
else System.out.println();
return;
}
if(flag==) System.out.println();
p[]=BigInteger.ONE;
for(int i=; i<=n; i++) p[i]=p[i-].multiply(BigInteger.valueOf(i));
ans=p[n-].divide(p[n--sum]);
for(int i=; i<n; i++) {
if(d[i]==-) continue;
ans=ans.divide(p[d[i]-]);
}
for(int i=; i<n--sum; i++) ans=ans.multiply(BigInteger.valueOf(n-cnt));
System.out.println(ans);
}
}