Cod sursa(job #1695918)

Utilizator leraValeria lera Data 27 aprilie 2016 23:54:22
Problema Dezastru Scor 50
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.9 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("dezastru.in");
ofstream fout("dezastru.out");
float s=0;
float a[26];
int v[26],n,t,ns=0;
void adunare()
{
    float p=1;
    for(int i=1;i<=t;i++)
        p=p*a[v[i]];
    s=s+p;
}
int solutie(int k)
{
    if(k==t)
        return 1;
    return 0;
}
int valid(int k)
{
    for(int i=1;i<=k-1;i++)
        if(v[i]==v[k])
            return 0;
        return 1;

}
void Bk(int k)
{
    for(int i=1;i<=n;i++)
    {
        v[k]=i;
        if(valid(k))
        {
            if(solutie(k))
                {
                    adunare();
                    ns++;
                }
            else
                 Bk(k+1);

        }
    }
}
int main()
{
    float rs;

    fin>>n>>t;
    for(int i=1;i<=n;i++)
        fin>>a[i];
    Bk(1);
    rs=(float)s/ns;
    fout<<rs;
    return 0;
}