Pagini recente » Cod sursa (job #3248345) | Cod sursa (job #675936) | Cod sursa (job #275949) | Cod sursa (job #3213129) | Cod sursa (job #3292083)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("dezastru.in");
ofstream fout("dezastru.out");
const int N=30;
int n,q,i,j,st[N],cnt;
bool f[N];
double v[N],p=1,t,ct;
void add()
{
p=1;
for(int i=1;i<=q;++i) p*=v[st[i]];
t+=p;
cnt++;
}
void bac(int k)
{
for(int i=st[k-1]+1;i<=n;++i)
{
st[k]=i;
//p*=v[i];
if( (!f[st[k]]))
{
f[i]=1;
if(k==q) add();
else bac(k+1);
f[i]=0;
}
//p/=v[i];
}
}
int main()
{
fin>>n>>q;
for(i=1;i<=n;++i)
{
fin>>v[i];
}
bac(1);
fout<<t/cnt;
return 0;
}