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