vijos1060 隔板法

排列组合问题

之前没有学过隔板法,随便学习了一下

其实挺好理解的

附上题解:

先只考虑一种球:
因为有n个盒子每个盒子可以放任意多球,还可以空出来任意多球。所以可以考虑为n+1个盒子,最后一个盒子里面是题中没放的球。
由于盒子可以空出来,所以将隔板与球一起排列 即在隔板和球组成的n+a列中 选出任意a个位置放隔板的话,就可以实现题目要求的效果!(0个或任意多个)。
两种球所以C(n+a,a)*C(n+b,b)。

 之后还需要注意精度问题

一直不是很注意这种事情,mark

最后一个点需要用到 unsigned long long

 

附上丑丑的代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;
int n,m,a,b; 
double sum1,sum2;
unsigned long long c;
int main(){
	scanf("%d%d%d",&n,&a,&b);
	sum1=1;
	for(int i=1+n;i<=a+n;i++){
		sum1=(sum1*i)/(i-n);
	}
	sum2=1;
	for(int i=n+1;i<=b+n;i++){
		sum2=(sum2*i)/(i-n);
    }
    c=sum1*sum2;
    cout<<c;
	return 0;
}

 哦...顺便提一下,自己之前写排列组合的时候,有时候会脑抽把它看成分子分母的乘积再相除

= =发现有bug...勿闹

posted @ 2014-08-30 23:55  polebug  阅读(184)  评论(0编辑  收藏  举报