Cod sursa(job #1231348)

Utilizator afkidStancioiu Nicu Razvan afkid Data 20 septembrie 2014 12:54:52
Problema Dezastru Scor 60
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.91 kb
#include <iostream>
#include <cstdio>

using namespace std;

int n,k,combinare[29],cnt;
double v[29],sum;

void backtrack(int i,int combinare[])
{
    if(i==k+1)
    {
        double p=1;
        for(int i=1;i<=k;++i)
            p*=v[combinare[i]];
        sum+=p;
        cnt++;
        return;
    }
    for(int t=1;t<=n;++t)
    {
        bool valid=true;
        for(int l=1;l<i;++l)
        {
            if(combinare[l]>=t)
                valid=false;
        }
        if(valid==true)
        {
            combinare[i]=t;
            backtrack(i+1,combinare);
        }
    }

}

int main()
{
    sum=0.0;
    cnt=0;
    freopen("dezastru.in","r",stdin);
    freopen("dezastru.out","w",stdout);
    scanf("%d %d",&n,&k);
    for(int i=1;i<=n;i++)
        {scanf("%lf",&v[i]);
        }
    backtrack(1,combinare);
    printf("%.6f",(float)sum/(float)cnt);
    return 0;
}