90分求调TwT
  • 板块P1497 木牛流马
  • 楼主criis
  • 当前回复0
  • 已保存回复0
  • 发布时间2024/12/14 14:05
  • 上次更新2024/12/14 16:46:28
查看原帖
90分求调TwT
1123694
criis楼主2024/12/14 14:05
#include<iostream>
using namespace std;
int he[10001];
int main(){
	int n,k,h,ans=1;
	cin>>n>>k>>h;
	for(int i=1;i<=h;i++)
	cin>>he[i];
	//每个颜色都一样时,
	//从n行中选k行有C(n,k)种方法,
	//选列时,每个数在所在的行能选的位置递减,所以是A(n,k) 
	for(int i=n;i>n-k;i--)
	ans*=i*i,ans/=(n-i+1);
	//如果有颜色之分,每种情况的相同颜色的位置要重新组合C(k,he[i]) 
	for(int i=1;i<=h-1;i++)
	{
        for(int j=k;j>k-he[i];j--) ans*=j,ans/=(he[i]-(k-j));
		k-=he[i];
	}
	cout<<ans;
	return 0;
}
2024/12/14 14:05
加载中...