BZOJ 1005 明明的烦恼 (组合数学)
题解:n为树的节点数,d[ ]为各节点的度数,m为无限制度数的节点数。
则
所以要求在n-2大小的数组中插入tot各序号,共有种插法;
在tot各序号排列中,插第一个节点的方法有种插法;
插第二个节点的方法有种插法;
.........另外还有m各节点无度数限制,所以它们可任意排列在剩余的n-2-tot的空间中,排列方法总数为
根据乘法原理:
#include <cstdio>
#include <cmath>
int n,m,tot,i,j,d,down[1005],up[1005],p[1005],ans[10005];
void pi(int x,int a[]){
for(int i=2;i<=x;i++)if(p[i]){
int sum=i; while(sum<=x)a[i]+=x/sum,sum*=i;
}
}
int main(){
scanf("%d",&n);
for(i=2;i<=1000;i++){
for(j=2;j<=std::sqrt(i);j++)
if(i%j==0)break;
if(j>sqrt(i))p[i]=1;
}
for(i=1;i<=n;i++){
scanf("%d",&d);
if(d==-1){m++;continue;}
if(d>1)pi(d-1,down);
tot+=d-1;
}
pi(n-2-tot,down);pi(n-2,up);
for(i=1;i<=1000;i++)up[i]-=down[i];
ans[0]=1;
for(i=1;i<=1000;i++)while(up[i]--){
for(j=0;j<=10000;j++)ans[j]*=i;
for(j=0;j<=10000;j++)if(ans[j]>9)ans[j+1]+=ans[j]/10,ans[j]%=10;
}
if(m)for(i=1;i<=n-2-tot;i++){
for(j=0;j<=10000;j++)ans[j]*=m;
for(j=0;j<=10000;j++)if(ans[j]>9)ans[j+1]+=ans[j]/10,ans[j]%=10;
}
if(tot>n-2||tot<n-2&&m==0)return puts("0"),0;
i=10000; while(!ans[i])i--;
while(~i)printf("%d",ans[i--]);
return 0;
}
BZOJ 1005 明明的烦恼 (组合数学)的更多相关文章
- [HNOI2008][bzoj 1005]明明的烦恼(prufer序列)
		1005: [HNOI2008]明明的烦恼 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 7121 Solved: 2816[Submit][Stat ... 
- BZOJ 1005 明明的烦恼 Prufer序列+组合数学+高精度
		题目大意:给定一棵n个节点的树的节点的度数.当中一些度数无限制,求能够生成多少种树 Prufer序列 把一棵树进行下面操作: 1.找到编号最小的叶节点.删除这个节点,然后与这个叶节点相连的点计入序列 ... 
- [BZOJ]1005 明明的烦恼(HNOI2008)
		BZOJ的第一页果然还是很多裸题啊,小C陆续划水屯些板子. Description 自从明明学了树的结构,就对奇怪的树产生了兴趣......给出标号为1到N的点,以及某些点最终的度数,允许在任意两点间 ... 
- BZOJ 1005 明明的烦恼
		Description 自从明明学了树的结构,就对奇怪的树产生了兴趣...... 给出标号为1到N的点,以及某些点最终的度数,允许在任意两点间连线,可产生多少棵度数满足要求的树? Input 第一行为 ... 
- BZOJ 1005 明明的烦恼(prufer序列+高精度)
		有一种东西叫树的prufer序列,一个树的与一个prufer序列是一一对应的关系. 设有m个度数确定的点,这些点的度为dee[i],那么每个点在prufer序列中出现了dee[i]-1次. 由排列组合 ... 
- BZOJ 1005: [HNOI2008]明明的烦恼( 组合数学 + 高精度 )
		首先要知道一种prufer数列的东西...一个prufer数列和一颗树对应..然后树上一个点的度数-1是这个点在prufer数列中出现次数..这样就转成一个排列组合的问题了.算个可重集的排列数和组合数 ... 
- BZOJ1005:[HNOI2008]明明的烦恼(组合数学,Prufer)
		Description 自从明明学了树的结构,就对奇怪的树产生了兴趣......给出标号为1到N的点,以及某些点最终的度数,允许在任意两点间连线,可产生多少棵度数满足要求的树? Input 第一行为N ... 
- BZOJ 1005 [HNOI2008] 明明的烦恼(组合数学 Purfer Sequence)
		题目大意 自从明明学了树的结构,就对奇怪的树产生了兴趣...... 给出标号为 1 到 N 的点,以及某些点最终的度数,允许在任意两点间连线,可产生多少棵度数满足要求的树? Input 第一行为 N( ... 
- BZOJ 1005 [HNOI2008]明明的烦恼 (Prufer编码 + 组合数学 + 高精度)
		1005: [HNOI2008]明明的烦恼 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 5786 Solved: 2263[Submit][Stat ... 
随机推荐
- UITextField 光标的位置设置获取
			UITextField 光标的位置设置获取 通过给UITextField 加一个拓展 //#import "UITextField+ExtentRange.h" #import & ... 
- 浅谈Mybatis(一)
			一.MyBatis引言 1.基本概念 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google co ... 
- Linux常用指令(待补充)
			1.cd进入目录 2../shuntdown.sh 停止tomcat 3.ps -ef |grep +进程名 查看进程状态 4.kill +进程名 强杀kill -9 +进程 5./start ... 
- BZOJ 1559: [JSOI2009]密码( AC自动机 + 状压dp )
			建AC自动机后, dp(x, y, s)表示当前长度为x, 在结点y, 包括的串的状态为s的方案数, 转移就在自动机上走就行了. 对于输出方案, 必定是由给出的串组成(因为<=42), 所以直接 ... 
- hadoop搭建杂记:Linux下虚拟机集群网络搭建
			VirtualBox搭建hadoop伪分布式模式 VirtualBox搭建hadoop伪分布式模式 master: ip:192.168.56.120 机器名: master 启动NameNode 启 ... 
- Gson使用初探
			参考地址: http://www.stormzhang.com/android/2014/05/22/android-gson/ 我的示例代码: public void doGsonTest(View ... 
- openStack windows2008 centos6.* img
			1,下载 windows2008 系统iso介质包 http://download.microsoft.com/download/F/3/8/F384E78B-8F1D-42A6-A308-63E45 ... 
- C++中搜索、截取字符串
			演示样例中有具体凝视,直接上代码: #include <iostream> #include <string> using std::cout; using std::endl ... 
- MyMVC框架的使用
			1)在web.config 中system.web 节点下加入例如以下代码 <pages controlRenderingCompatibilityVersion="4.0" ... 
- Node.js 小工具--supervisor
			Node.js 在写文件的时候 一旦更改.每次都得重新运行 app.js. 很麻烦. supervisor 工具可以帮助你 监听文件改动,自动重启. sudo npm install -g super ... 
 
			
		

