Cod sursa(job #1831882)

Utilizator robertkarolRobert Szarvas robertkarol Data 18 decembrie 2016 22:44:30
Problema Dezastru Scor 60
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.58 kb
#include <iostream>
#include <fstream>
using namespace std;

ifstream fin("dezastru.in");
ofstream fout("dezastru.out");

int i,n,k,st[26];
double v[26],p=1.0f,rez,f[26];

void back(int niv)
{
    int i;
    for(i=st[niv-1]+1;i<=n;i++)
    {
        st[niv]=i;
        p*=v[i];
        if(niv==k)
            rez+=p;
        else back(niv+1);
        p/=v[i];
    }
}
int main()
{
    fin>>n>>k;
    f[1]=1;
    for(i=2;i<=n;i++)
        f[i]=f[i-1]*i;
    for(i=1;i<=n;i++)
        fin>>v[i];
    back(1);
    fout<<rez/(f[n]/f[k]/f[n-k]);
    return 0;
}