#include <bits/stdc++.h>
using namespace std;
double Prawdopodobienstwo(const vector<double>& p, int n, int x) {
vector<double> dp(n + 1, 0.0);
dp[0] = 1.0;
for (int i = 0; i < n; i++) {
for (int k = n; k > 0; --k) {
dp[k] = dp[k] * (1 - p[i]) + dp[k - 1] * p[i];
}
dp[0] *= (1 - p[i]);
}
double wynik = 1.0;
for (int k = 0; k < x; ++k) {
wynik -= dp[k];
}
return wynik;
}
int IleDobrze(int odp,int t)
{
int ile=t;
odp=odp-t;
if(odp%2==1)
ile+=odp/2+1;
else
ile+=odp/2;
return ile;
}
int main()
{
std::ios_base::sync_with_stdio(0);
cin.tie(0);
int n,t;
cin>>n>>t;
vector <double> vec;
vector <double> odpowiedzi;
double p;
for(int i=0;i<n;i++)
{
cin>>p;
vec.push_back(p);
}
sort(vec.begin(), vec.end(), greater<double>());
int odp=t;
while(odp<=n)
{
int a=IleDobrze(odp, t);
odpowiedzi.push_back(Prawdopodobienstwo(vec, odp, a));
odp++;
}
sort(odpowiedzi.begin(), odpowiedzi.end(), greater<double>());
if(odpowiedzi[0]<pow(10, -7))
cout<<"0";
else
cout<<odpowiedzi[0];
return 0;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | #include <bits/stdc++.h> using namespace std; double Prawdopodobienstwo(const vector<double>& p, int n, int x) { vector<double> dp(n + 1, 0.0); dp[0] = 1.0; for (int i = 0; i < n; i++) { for (int k = n; k > 0; --k) { dp[k] = dp[k] * (1 - p[i]) + dp[k - 1] * p[i]; } dp[0] *= (1 - p[i]); } double wynik = 1.0; for (int k = 0; k < x; ++k) { wynik -= dp[k]; } return wynik; } int IleDobrze(int odp,int t) { int ile=t; odp=odp-t; if(odp%2==1) ile+=odp/2+1; else ile+=odp/2; return ile; } int main() { std::ios_base::sync_with_stdio(0); cin.tie(0); int n,t; cin>>n>>t; vector <double> vec; vector <double> odpowiedzi; double p; for(int i=0;i<n;i++) { cin>>p; vec.push_back(p); } sort(vec.begin(), vec.end(), greater<double>()); int odp=t; while(odp<=n) { int a=IleDobrze(odp, t); odpowiedzi.push_back(Prawdopodobienstwo(vec, odp, a)); odp++; } sort(odpowiedzi.begin(), odpowiedzi.end(), greater<double>()); if(odpowiedzi[0]<pow(10, -7)) cout<<"0"; else cout<<odpowiedzi[0]; return 0; } |
English