Cod sursa(job #1695947)

Utilizator leraValeria lera Data 28 aprilie 2016 00:58:24
Problema Dezastru Scor 10
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.89 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("dezastru.in");
ofstream fout("dezastru.out");
float s=0;
float a[26];
float p=1;
int v[26],n,t,ns;
/*void adunare(int k)
{
    p=p*a[v[k]];
    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,float p)
{

    for(int i=1;i<=n;i++)
    {
        v[k]=i;
        if(valid(k))
        {
            if(solutie(k))
                {

                    s=s+p*a[v[k]];
                }
            else
                 Bk(k+1,p*a[v[k]]);

        }
    }
}
int main()
{
    float rs;

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