Pagini recente » Cod sursa (job #1205719) | Cod sursa (job #3151447) | Cod sursa (job #835534) | Cod sursa (job #1488597) | Cod sursa (job #782116)
Cod sursa(job #782116)
#include <iostream>
#include <iomanip>
#include <fstream>
using namespace std;
ifstream fin("dezastru.in");
ofstream fout("dezastru.out");
int st[30], N, K, nr, i, j;
float v[30], S, prod;
int valid(int k)
{
for(i=1; i<k; i++)
if(st[i]==st[k])
return 0;
return 1;
}
void back(int k)
{
int i;
for(i=1; i<=N; i++)
{
st[k]=i;
if(valid(k)) if(k==K){
prod=1;
for(j=1; j<=k; j++)
prod*=v[st[j]];
S+=prod/nr;
}
else back(k+1);
}
}
int main()
{
fin>>N>>K;
nr=1;
for(i=1; i<=N; i++)
{
nr*=i;
fin>>v[i];
}
back(1);
fout<<setprecision(6)<<S;
fin.close();
fout.close();
return 0;
}