CodeForces - 261B Maxim and Restaurant

Posted Sky_miner

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CodeForces - 261B Maxim and Restaurant相关的知识,希望对你有一定的参考价值。

http://codeforces.com/problemset/problem/261/B

题目大意:给定n个数a1…an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a3…+ai,问满足Si<=p的i的最大值的期望.(p<=50)

(大意来自于http://www.cnblogs.com/liu-runda/p/6253569.html)

我们知道,全排列其实等价于我们一个一个地等概率地向一个序列里面插入数值

所以我们可以这么看这道题:
 现在有n个数,有n个盒子,等概率地把这些数放入盒子,求Si<=p的max[i]的期望

我们考虑每个盒子对于答案的贡献

如果第一个盒子保存下来了,那么它的贡献就是p(保存下来的概率)

所以我们只需要计算每个盒子保存下来的概率就可以了

我们又发现:如果第i个盒子保存下来了,那么1~(i-1)的盒子一定都保存下来了

不然第i个盒子就不可能保存下来,原文中:
Maxim doesn\'t let any other guest in the restaurant
even if one of the following guests in the queue would have fit in at the table.
起到了关键作用

所以我们定义f[i][j][k]表示在前i个数中随机的把数放到盒子里
前j个盒子被放满且前j个盒子中的数之和为k的情况出现的概率

那么我们有f[i][j][k] = f[i-1][j][k]*(1 - (j/i)) + f[i-1][j-1][k - a[i]]*(j/i)

则ans = sigma{f[n][i][j]}(1<=i<=n;0<=j<=p)

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <algorithm>
 4 using namespace std;
 5 typedef long long ll;
 6 inline void read(int &x){
 7     x=0;char ch;bool flag = false;
 8     while(ch=getchar(),ch<\'!\');if(ch == \'-\') ch=getchar(),flag = true;
 9     while(x=10*x+ch-\'0\',ch=getchar(),ch>\'!\');if(flag) x=-x;
10 }
11 inline int cat_max(const int &a,const int &b){return a>b ? a:b;}
12 inline int cat_min(const int &a,const int &b){return a<b ? a:b;}
13 const int maxn = 66;
14 double f[2][maxn][maxn];
15 int a[maxn];
16 int main(){
17     int n;read(n);
18     for(int i=1;i<=n;++i) read(a[i]);
19     int p;read(p);
20     f[0][0][0] = 1.0;
21     for(int i=1;i<=n;++i){
22         for(int j=0;j<=i;++j){
23             for(int k=0;k<=p;++k){
24                 if(a[i] > k) f[i&1][j][k] = f[(i-1)&1][j][k]*(i-j)/i;
25                 else f[i&1][j][k] = f[(i-1)&1][j][k]*(i-j)/i + f[(i-1)&1][j-1][k-a[i]]*j/i;
26             }
27         }
28     }
29     double ans = .0;
30     for(int i=1;i<=n;++i){
31         for(int j=0;j<=p;++j){
32             ans += f[n&1][i][j];
33         }
34     }printf("%.10lf\\n",ans);
35     getchar();getchar();
36     return 0;
37 }
38   

 

以上是关于CodeForces - 261B Maxim and Restaurant的主要内容,如果未能解决你的问题,请参考以下文章

CF261B Maxim and Restaurant

CodeForces - 261E Maxim and Calculator

CodeForces 721D Maxim and Array

CodeForces 721D Maxim and Array

Maxim and Array CodeForces - 721D (贪心)

Codeforces 854 B Maxim Buys an Apartment 思维 水题