Pagini recente » Cod sursa (job #245743) | Cod sursa (job #1049084) | Cod sursa (job #607563) | Cod sursa (job #551718) | Cod sursa (job #2493314)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fi ("dezastru.in");
ofstream fo ("dezastru.out");
int n,k,st[30],nrp;
double v[30],sum;
int valid(int niv)
{ int i;
for(i=1;i<niv;i++)
if(st[i]==st[niv])
return 0;
return 1;
}
void sol()
{double x=1;
for(int i=1;i<=k;i++)
x*=v[st[i]];
sum+=x;
}
void bkt(int niv)
{ int i;
for(i=1;i<=n;i++)
{
st[niv]=i;
if(valid(niv)==1)
{
if(niv==n)
{
sol();
nrp++;
}
else bkt(niv+1);
}
}
}
int main()
{ double x;
fi>>n>>k;
for(int i=1;i<=n;i++)
fi>>v[i];
bkt(1);
x=double(sum/nrp);
fo<<x;
fi.close();
fo.close();
return 0;
}