Pagini recente » Cod sursa (job #1983090) | Cod sursa (job #2014458) | Cod sursa (job #3283003) | Cod sursa (job #3202289) | Cod sursa (job #3293679)
#include <fstream>
using namespace std;
ifstream fin("dezastru.in");
ofstream fout("dezastru.out");
double sum,v[30];
int n,q,i,st[30],viz[30],cnt;
void bkt(int k,double produs)
{
int i;
for(i=st[k-1]+1;i<=n-q+k;i++)
{
if(viz[i]==0)
{
viz[i]=1;
st[k]=i;
if(k==q) {cnt++;sum+=produs*v[i];}
else bkt(k+1,produs*v[i]*1.0);
viz[i]=0;
}
}
}
int main()
{
fin>>n>>q;
for(i=1;i<=n;i++)
{
fin>>v[i];
}
bkt(1,1);
//for(i=1;i<=n;i++) sum=1.0*sum/i;
fout<<sum/cnt;
return 0;
}