forked from Diusrex/UVA-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path10171 Meeting Prof Miguel.cpp
80 lines (68 loc) · 2.1 KB
/
10171 Meeting Prof Miguel.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
#include <iostream>
#include <cmath>
#include <vector>
using namespace std;
const int Inf = 1e9;
int youngCost[27][27];
int oldCost[27][27];
void AddEdge(char direction, char X, char Y, int cost, int array[27][27])
{
array[X - 'A'][Y - 'A'] = min(cost, array[X - 'A'][Y - 'A']);
if (direction == 'B')
array[Y - 'A'][X - 'A'] = min(cost, array[Y - 'A'][X - 'A']);
}
int main()
{
int E;
while (cin >> E, E)
{
for (int i = 0; i < 26; ++i)
{
for (int j = 0; j < 26; ++j)
youngCost[i][j] = oldCost[i][j] = Inf;
youngCost[i][i] = oldCost[i][i] = 0;
}
while (E--)
{
int cost;
char age, direction, X, Y;
cin >> age >> direction >> X >> Y >> cost;
if (age == 'Y')
AddEdge(direction, X, Y, cost, youngCost);
else
AddEdge(direction, X, Y, cost, oldCost);
}
for (int k = 0; k < 26; ++k)
for (int i = 0; i < 26; ++i)
for (int j = 0; j < 26; ++j)
{
youngCost[i][j] = min(youngCost[i][j], youngCost[i][k] + youngCost[k][j]);
oldCost[i][j] = min(oldCost[i][j], oldCost[i][k] + oldCost[k][j]);
}
int cost = Inf - 1;
char youngS, oldS;
vector<char> meetSpots;
cin >> youngS >> oldS;
for (int meet = 0; meet < 26; ++meet)
{
int cCost = youngCost[youngS - 'A'][meet] + oldCost[oldS - 'A'][meet];
if (cCost < cost)
{
meetSpots.clear();
meetSpots.push_back(meet + 'A');
cost = cCost;
}
else if (cCost == cost)
meetSpots.push_back(meet + 'A');
}
if (meetSpots.size())
{
cout << cost;
for (int i = 0; i < meetSpots.size(); ++i)
cout << ' ' << meetSpots[i];
cout << '\n';
}
else
cout << "You will never meet.\n";
}
}