Pagini recente » Cod sursa (job #236219) | Cod sursa (job #2089904) | Cod sursa (job #1907090) | Cod sursa (job #2829515) | Cod sursa (job #3210650)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("dezastru.in");
ofstream g("dezastru.out");
int n,p;
float prob[30];
int x[30];
bool used[30];
float sum=0;
void sol()
{
float sp=0;
for(int i=1;i<=p;i++)
sp+=prob[x[i]];
sum+=sp;
}
void gen(int k)
{
if(k>n)
sol();
else for(int i=x[k-1]; i<=n; i++)
if(!used[i])
{
x[k]=i;
used[i]=1;
gen(k+1);
used[i]=0;
}
}
int comb(int n,int k)
{
if(k>n-k)
k=n-k;
int f=1,c=1;
for(int i=1;i<=k;i++)
{
c=c*(n-i+1);
f=f*i;
}
c/=f;
return c;
}
int main()
{
int i;
f>>n>>p;
x[0]=1;
for(int i=1; i<=n; i++)
f>>prob[i];
gen(1);
g<<1.0*sum/comb(n,p);
f.close();
g.close();
return 0;
}