Pagini recente » Cod sursa (job #1620267) | Cod sursa (job #1803178) | Cod sursa (job #2139749) | Cod sursa (job #705054) | Cod sursa (job #438057)
Cod sursa(job #438057)
#include <stdio.h>
int N, K;
double prob[30];
double S = 0;
int fact = 0;
void back (int k, double x, int last)
{
if (k == K + 1)
{
S += x;
fact ++;
}
else
{
for (int i = last + 1; i <= N - K + k; ++i)
back(k + 1, x * prob[i], i);
}
}
int main()
{
int i;
FILE *f = fopen ("dezastru.in", "r");
FILE *g = fopen ("dezastru.out", "w");
fscanf (f,"%d %d", &N, &K);
for (i=1; i<=N; i++)
fscanf (f,"%lf", &prob[i]);
back(1, 1, 0);
fprintf (g,"%lf\n", S / fact);
fclose(g);
fclose(f);
return 0;
}