-
Notifications
You must be signed in to change notification settings - Fork 363
/
Copy pathshunting_yard.hpp
105 lines (95 loc) · 4.52 KB
/
shunting_yard.hpp
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
94
95
96
97
98
99
100
101
102
103
104
105
/*
Shunting Yard
----------------------------------------------
Converting an infix arithmetic string to a post-fix one, A.K.A. Reverse Polish Notation.
This implementation does not implement functions and solely focuses on simple arithmetic of consisting of [-,+,*,/,^]
Time complexity
---------------
O(N*M*P) where N is the size of input vector, i.e. equations,
M is the size of the greatest string in the vector,
and P is maximum number of operators in the string
Space complexity
----------------
O(N+P) = O(N) : where N is the size of input vector, i.e. equations,
and P is maximum number of operators in the string, i.e. stack operations.
*/
#ifndef SHUNTING_YARD_HPP
#define SHUNTING_YARD_HPP
#include <iostream>
#include <vector>
#include <string>
#include <stack>
#include <unordered_map>
#include <algorithm>
using std::string;
class OperatorOperations {
public:
static std::vector<std::string> to_reverse_polish(const std::vector<std::string> &);
static std::unordered_map<char, int> operator_precedence;
static std::unordered_map<char, std::string> operator_association;
};
std::unordered_map<char, int> OperatorOperations::operator_precedence{{'-', 2},
{'+', 2},
{'*', 3},
{'/', 3},
{'^', 4}};
std::unordered_map<char, std::string> OperatorOperations::operator_association{{'-', "left"},
{'+', "left"},
{'*', "left"},
{'/', "left"},
{'^', "right"}};
std::vector<std::string> OperatorOperations::to_reverse_polish(const std::vector<std::string> &equations) {
string equation;
string temporary_string;
std::vector<string> postfixed_equations;
postfixed_equations.reserve(equations.size());
std::stack<char> operators;
for (int i = 0; i <= (int) equations.size() - 1; i++) {
equation = equations[i];
temporary_string = "";
for (int j = 0; j <= (int) equation.length() - 1; j++) {
if (isalnum(equation[j])) {
temporary_string.push_back(equation[j]);
} else if (isblank(equation[j])) {
// do nothing
} else if (equation[j] != '(' && equation[j] != ')' &&
operator_precedence.find(equation[j]) == operator_precedence.end()) {
temporary_string.push_back(equation[j]);
} else {
if (equation[j] == '(') {
operators.push(equation[j]);
} else {
if (equation[j] == ')') {
while (operators.top() != '(') {
temporary_string.push_back(operators.top());
operators.pop();
}
operators.pop();
} else {
if (operators.empty()) {
operators.push(equation[j]);
} else {
while (!operators.empty() && (operators.top() != '(') &&
(OperatorOperations::operator_precedence[operators.top()] >
OperatorOperations::operator_precedence[equation[j]] ||
(OperatorOperations::operator_precedence[operators.top()] ==
OperatorOperations::operator_precedence[equation[j]] &&
OperatorOperations::operator_association[operators.top()] == "left"))) {
temporary_string.push_back(operators.top());
operators.pop();
}
operators.push(equation[j]);
}
}
}
}
}
while (!operators.empty()) {
temporary_string.push_back(operators.top());
operators.pop();
}
postfixed_equations.push_back(temporary_string);
}
return postfixed_equations;
}
#endif // SHUNTING_YARD_HPP