首页 > 其他 > 详细

hdu 4372 第一类stirling数的应用/。。。好题

时间:2014-05-13 20:56:18      阅读:414      评论:0      收藏:0      [点我收藏+]
bubuko.com,布布扣
 1 /**
 2 大意: 给定一系列楼房,都在一条水平线上,高度从1到n,从左侧看能看到f个, 从右侧看,能看到b个,问有多少种这样的序列。。
 3 思路: 因为肯定能看到最高的,,那我们先假定最高的楼房位置确定,那么在其左边还有f-1个能看见,在其右边还有b-1个,能看见。。所以可以这样将题目转化: 将除最高楼之外的n-1个楼,分成f-1+b-1 组,在最高楼左边f-1 组,在其右边b-1组,那么分成f-1+b-1 组  就是第一类Stirling数。s[n-1][f-1+b-1]。。左边f-1 组,在其右边b-1组,就是将这f-1+b-1 组,组合c(f-1+b-1,f-1)
 4 **/
 5 
 6 #include <iostream>
 7 
 8 using namespace std;
 9 const long long mod = 1000000007;
10 long long c[2010][2010];
11 long long s[2010][2010];
12 
13 void init(){
14     c[0][0] =1;
15     for(int i=1;i<=2000;i++){
16         c[i][0] = c[i][i] =1;
17         for(int j=1;j<i;j++){
18             c[i][j] = (c[i-1][j]+c[i-1][j-1])%mod;
19         }
20     }
21 
22     for(int i=1;i<=2000;i++){
23         s[i][0] =0;
24         s[i][i] =1;
25         for(int j=1;j<i;j++)
26             s[i][j] = (s[i-1][j-1]+(s[i-1][j]*(i-1))%mod)%mod;
27     }
28 
29 }
30 
31 int main()
32 {
33     init();
34     int t;
35     cin>>t;
36     while(t--){
37         int n,f,b;
38         cin>>n>>f>>b;
39         long long res =0;
40        if(f+b-1<=2000)
41             res = (s[n-1][f+b-2]*c[f+b-2][f-1])%mod;
42         else
43             res =0;
44         cout<<res<<endl;
45     }
46     return 0;
47 }
bubuko.com,布布扣

 

hdu 4372 第一类stirling数的应用/。。。好题,布布扣,bubuko.com

hdu 4372 第一类stirling数的应用/。。。好题

原文:http://www.cnblogs.com/Bang-cansee/p/3724077.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!