Pagini recente » Cod sursa (job #2842882) | Cod sursa (job #1838438) | Cod sursa (job #270995) | Cod sursa (job #499541) | Cod sursa (job #2493312)
#include <fstream>
#include <iomanip>
using namespace std;
ifstream cin("dezastru.in");
ofstream cout("dezastru.out");
int n,k,i,st[30],viz[30];
double v[30],sum;
long long fact(int x)
{
int j;
long long p;
p=1;
for(j=2;j<=x;j++)
p=p*j;
return p;
}
void tipar(int vf)
{
int j;
double p=1.0;
for(j=1;j<=vf;j++)
{
p=p*v[st[j]];
///cout<<p<<" ";
}
///cout<<endl;
sum+=p;
}
void bkt(int vf)
{
int j;
for(j=1;j<=n;j++)
{
if(viz[j]==0)
{
st[vf]=j;
viz[j]=1;
if(vf==k)
tipar(vf);
else
bkt(vf+1);
viz[j]=0;
}
}
}
int main()
{
cin>>n>>k;
for(i=1;i<=n;i++)
{
cin>>v[i];
}
bkt(1);
cout<<setprecision(6)<<sum/fact(n);
///cout<<sum;
return 0;
}