Cod sursa(job #1243780)

Utilizator Andrei11Andrei Andrei11 Data 16 octombrie 2014 13:42:04
Problema Dezastru Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.84 kb
#include <stdio.h>
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("dezastru.in");
ofstream g("dezastru.out");

int st[25],k,n; float suma,v[25];

bool valid(int p)
{
    for(int i=1;i<p;i++)
    {
        if(st[i]==st[p])return 0;
    }
    return true;
}
int factorial(int n)
{
    if(n==1) return 1;
    else return n*factorial(n-1);
}
void rezolvare()
{
    float sum=1;
    for(int i=1;i<=k;i++)
    {
        sum*=v[st[i]];
    }
    suma+=sum/factorial(n);
}
void back(int k)
{
    if(k>n) rezolvare();
    else
    {
        for(int i=1;i<=n;i++)
        {
            st[k]=i;
            if(valid(k))
                back(k+1);
        }
    }
}
int main()
{
    f>>n>>k;
    for(int i=1;i<=n;i++)
    {
        f>>v[i];
    }
    back(1);
    cout<<suma;


    return 0;
}