Pagini recente » Cod sursa (job #2793722) | Cod sursa (job #3036678) | Cod sursa (job #1287312) | Cod sursa (job #623046) | Cod sursa (job #1198425)
#include <iostream>
#include <cstdio>
using namespace std;
FILE *f=fopen ("dezastru.in","r");
FILE *g=fopen ("dezastru.out","w");
int v[10000],n,k,kfac=1,nfac=1;
float a[100],s,rez,rezt;
void afisare()
{
s=1;
for (int i=1;i<=k;i++) s*=a[v[i]];
rez+=s;
}
void Back(int p)
{
for (int i=v[p-1]+1;i<=n;i++)
{
v[p]=i;
if (p==k) afisare ();
if (p<k) Back (p+1);
}
}
int main()
{
fscanf (f,"%d %d",&n,&k);
int i;
for (i=1;i<=n;i++) {fscanf (f,"%f",&a[i]);nfac*=i;}
for (i=1;i<=k;i++) kfac*=i;
v[0]=0;
Back (1);
rezt=rez*kfac/nfac;
fprintf (g,"%6f",rezt);
return 0;
}