Pagini recente » Cod sursa (job #510220) | Cod sursa (job #581112) | Cod sursa (job #2444471) | Cod sursa (job #3208615) | Cod sursa (job #2514617)
#include <fstream>
using namespace std;
ifstream fin("dezastru.in");
ofstream fout("dezastru.out");
int n, k, v[32], nr;
double prob[32], res;
void citire() {
fin >> n >> k;
for(int i = 1; i <= n; i++)
fin >> prob[i];
}
bool valid(int p) {
return v[p] > v[p-1];
}
bool solutie(int p) {
return p == k;
}
void calc(double p) {
nr++;
res = (double)res+p;
}
void backtracking(int p,double prb) {
for(int i = v[p-1]+1; i <= n; i++) {
v[p]= i;
if(valid(p)) {
if(solutie(p))
calc((double)prb*prob[v[p]]);
else
backtracking(p+1, (double)prb*prob[v[p]]);
}
}
}
int main() {
citire();
backtracking(1, double(1.0));
res = (double)res/ nr;
fout << res;
}