forked from s-kachroo/SamsungPractice
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdoctor probability.cpp
84 lines (69 loc) · 2.3 KB
/
doctor probability.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
https://www.geeksforgeeks.org/samsung-interview-experience-set-39-campus-r-d-noida/
https://www.careercup.com/page?pid=samsung-interview-questions
A Doctor travels from a division to other division where divisions are connected like a graph(directed graph) and
the edge weights are the probabilities of the doctor going from that division to other connected division but the
doctor stays 10mins at each division now there will be given time and had to find the division in which he will be
staying by that time and is determined by finding division which has high probability.
Input is number of test cases followed by the number of nodes, edges, time after which we need to find the division
in which he will be there, the edges starting point, end point, probability.
Note: If he reaches a point where there are no further nodes then he leaves the lab after 10 mins and the traveling
time is not considered and during that 10min at 10th min he will be in next division, so be careful
2
6 10 40
1 2 0.3 1 3 0.7 3 3 0.2 3 4 0.8 2 4 1 4 5 0.9 4 4 0.1 5 6 1.0 6 3 0.5 6 6 0.5
6 10 10
1 2 0.3 1 3 0.7 3 3 0.2 3 4 0.8 2 4 1 4 5 0.9 4 4 0.1 5 6 1.0 6 3 0.5 6 6 0.5
6 0.774000
3 0.700000
*/
#include<iostream>
using namespace std;
void docProb(double **graph, int nodes, int time, int curNode, double p, double *answer){
if(time <= 0){
answer[curNode] += p;
return;
}
for(int i=1; i<=nodes; i++){
if(graph[curNode][i] != 0){
p *= graph[curNode][i];
docProb(graph, nodes, time - 10, i, p, answer);
p /= graph[curNode][i];
}
}
}
int main(){
int t;
cin >> t;
while(t--){
int nodes, edges, time;
cin >> nodes >> edges >> time;
double **arr = new double*[nodes];
for(int i=1; i<=nodes; i++){
arr[i] = new double[nodes];
for(int j=1; j<=nodes; j++){
arr[i][j] = 0;
}
}
int from, to;
double prob;
for(int i=0; i<edges; i++){
cin >> from >> to >> prob;
arr[from][to] = prob;
}
/* Initalise answer and function call */
double answer[nodes] = {0.0};
docProb(arr, nodes, time, 1, 1.0, answer);
/* Select max Probability node */
double finalProb = 0.0;
int finalDivison = 0;
for(int i=1; i<=nodes; i++){
if(answer[i] > finalProb){
finalProb = answer[i];
finalDivison = i;
}
}
cout << finalDivison << " " << finalProb << "\n";
}
return 0;
}