forked from haoel/leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
EvaluateDivision.cpp
93 lines (78 loc) · 3.29 KB
/
EvaluateDivision.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
85
86
87
88
89
90
91
92
93
// Source : https://leetcode.com/problems/evaluate-division/
// Author : Hao Chen
// Date : 2016-11-05
/***************************************************************************************
*
* Equations are given in the format A / B = k, where A and B are variables
* represented as strings, and k is a real number (floating point number). Given some
* queries, return the answers. If the answer does not exist, return -1.0.
*
* Example:
* Given a / b = 2.0, b / c = 3.0. queries are: a / c = ?, b / a = ?, a / e = ?, a
* / a = ?, x / x = ? . return [6.0, 0.5, -1.0, 1.0, -1.0 ].
*
* The input is: vector<pair<string, string>> equations, vector<double>& values,
* vector<pair<string, string>> queries , where equations.size() == values.size(), and
* the values are positive. This represents the equations. Return vector<double>.
*
* According to the example above:
* equations = [ ["a", "b"], ["b", "c"] ],
* values = [2.0, 3.0],
* queries = [ ["a", "c"], ["b", "a"], ["a", "e"], ["a", "a"], ["x", "x"] ].
*
* The input is always valid. You may assume that evaluating the queries will result in
* no division by zero and there is no contradiction.
***************************************************************************************/
class Solution {
private:
bool dfs( unordered_map<string, unordered_map<string, double>>& m,
unordered_map<string, bool>& visited,
string& start, string& end, double& res ) {
if ( m.find(start) == m.end() || m.find(end) == m.end() ) return false;
if ( start == end ) return true;
for (auto it = m[start].begin(); it != m[start].end(); ++it) {
auto key = it->first;
auto value = it->second;
// already visited, skip it.
if (visited.find(key) != visited.end() ) {
continue;
}
visited[key] = true;
double old = res;
res *= value;
if (dfs(m, visited, key, end, res)) {
return true;
}
//didn't find the result, reset the current result, and go to next one
res = old;
visited.erase(key);
}
return false;
}
public:
vector<double> calcEquation(vector<pair<string, string>> equations,
vector<double>& values,
vector<pair<string, string>> queries) {
unordered_map<string, unordered_map<string, double>> m;
for(int i=0; i<equations.size(); i++) {
auto first = equations[i].first;
auto second = equations[i].second;
m[first][second] = values[i];
m[second][first] = 1.0 / values[i];
}
vector<double> result;
for(auto q : queries) {
string start = q.first;
string end = q.second;
unordered_map<string, bool> visited;
visited[start] = true;
double res = 1.0;
if(dfs(m, visited, start, end, res)) {
result.push_back(res);
} else {
result.push_back(-1.0);
}
}
return result;
}
};