-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrpn_demo.cpp
106 lines (89 loc) · 2.88 KB
/
rpn_demo.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
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <iostream>
#include <stack>
using namespace std;
// 将中序运算符字符串转换为 逆波兰表达式(RPN)
#define N_OPTR 9
const char pri[N_OPTR][N_OPTR] = {
// 当前运算符
/* + - * / ^ ! ( ) \0 */
/* 栈 */
/* + */ '>', '>', '<', '<', '<', '<', '<', '>', '>',
/* - */ '>', '>', '<', '<', '<', '<', '<', '>', '>',
/* * */ '>', '>', '>', '>', '<', '<', '<', '>', '>',
/* / */ '>', '>', '>', '>', '<', '<', '<', '>', '>',
/* ^ */ '>', '>', '>', '>', '>', '<', '<', '>', '>',
/* ! */ '>', '>', '>', '>', '>', '>', '<', '>', '>',
/* ( */ '<', '<', '<', '<', '<', '<', '<', '=', ' ',
/* ) */ ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
/* \0 */ '<', '<', '<', '<', '<', '<', '<', ' ', '='
/* 顶*/
};
const char table[] = {'+', '-', '*', '/', '^', '!', '(', ')', '\0'};
bool is_digit(char const c) {
return c >= '0' && c<='9';
}
void read_digit(char const* &S, stack<int>& opond) {
int sum = 0;
while(is_digit(*S)) {
sum = 10*sum + (int)(*S-'0');
S++;
}
opond.push(sum);
}
int get_pos(char const c) {
int length = (sizeof(table)/sizeof(char));
for(int i = 0; i < length; i++) {
if (table[i] == c) return i;
}
return -1;
}
// 返回运算符 c1 c2优先级比较结果
char primer_result(char const c1, char const c2) {
int pos1 = get_pos(c1);
int pos2 = get_pos(c2);
return pos1 == -1 || pos2 == -1 ? ' ': pri[pos1][pos2];
}
// S 中序运算符字符串
void generate_rpn(char const* S){
stack<char> optr;// 存储运算符
stack<int> opond;// 存储操作数
optr.push('\0');
while(*S != '\0') { // optr 非空
char c = *S;
if (is_digit(c)) {
read_digit(S, opond);
cout<<opond.top()<<" ";
} else {
switch (primer_result(optr.top(), *S)) {
case '<':
optr.push(*S);
S++;
break;
case '=':
optr.pop();
S++;
break;
case '>':
cout<<optr.top()<<" ";
optr.pop();
break;
default: exit(-1);
}// switch
}// else
}//while
while (!optr.empty()){
cout<<optr.top()<<" ";
optr.pop();
}
}
int main() {
char buffer[256];
while(true){
cout<<"输入中序表达式(输入0 结束):";
cin.getline(buffer, 256);
if (buffer[0] == '0' && buffer[1] == '\0') break;
generate_rpn(buffer);
cout<<endl;
memset(buffer, ' ', 256);
}
}