Pagini recente » Cod sursa (job #1369111) | Cod sursa (job #2589320) | Cod sursa (job #2549269) | Cod sursa (job #129105) | Cod sursa (job #438067)
Cod sursa(job #438067)
#include <stdio.h>
int N, K;
float prob[26];
float S = 0;
int fact = 0;
void back (int k, float x, int last)
{
if (k == K + 1)
{
S += x;
fact ++;
}
else
{
for (register int i = last + 1; i <= N - K + k; ++i)
back(k + 1, x * prob[i], i);
}
}
int main()
{
freopen ("dezastru.in", "r", stdin);
freopen ("dezastru.out", "w", stdout);
scanf("%d %d", &N, &K);
for (register int i=1; i<=N; i++)
scanf("%f", &prob[i]);
back(1, 1, 0);
printf("%6f", S / fact);
fclose(stdin);
fclose(stdout);
return 0;
}