Cod sursa(job #2493319)

Utilizator Lazar_VladLazar Vlad Lazar_Vlad Data 16 noiembrie 2019 11:36:44
Problema Dezastru Scor 50
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.82 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream fi ("dezastru.in");
ofstream fo ("dezastru.out");
int n,k,st[30],nrp;
double v[30],sum;
int valid(int niv)
{ int i;
    for(i=1;i<niv;i++)
        if(st[i]==st[niv])
            return 0;
    return 1;
}

void sol()
{double x=1;
    for(int i=1;i<=k;i++)
        x*=v[st[i]];
    sum+=x;
}

void bkt(int niv)
{ int i;
    for(i=1;i<=n;i++)
    {
        st[niv]=i;
        if(valid(niv)==1)
        {
            if(niv==k)
            {
                sol();
                nrp++;
            }
            else bkt(niv+1);
        }
    }
}
int main()
{ double x;
    fi>>n>>k;
    for(int i=1;i<=n;i++)
        fi>>v[i];
    bkt(1);
    x=double(sum/nrp);
    fo<<x;
    fi.close();
    fo.close();
    return 0;
}