Pagini recente » Cod sursa (job #1627790) | Diferente pentru problema/brperm intre reviziile 31 si 30 | Cod sursa (job #1231490) | Diferente pentru problema/cascaval intre reviziile 6 si 5 | Cod sursa (job #2026917)
#include<fstream>
using namespace std;
ifstream fin("dezastru.in");
ofstream fout("dezastru.out");
int n,k;
long double x[35],s,t,nr;
int y[35];
void ve(int poz)
{
if(poz==k+1)
{
nr++;
s+=t;
return;
}
for(int i=1;i<=n;i++)
if(!y[i])
{
y[i]=1;
if(poz<=k)
t*=x[i];
ve(poz+1);
y[i]=0;
if(poz<=k)
t/=x[i];
}
}
int main()
{
fin>>n>>k;
t=1;
for(int i=1;i<=n;i++)
fin>>x[i];
ve(1);
fout<<s/nr;
}