-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
51 lines (45 loc) · 1.06 KB
/
main.go
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
package main
import (
"strconv"
)
func evalRPN(tokens []string) int {
stack := []int{} // 用数组实现一个栈
for _, token := range tokens {
if token != "+" && token != "-" && token != "*" && token != "/" {
num, _ := strconv.Atoi(token)
stack = append(stack, num)
} else {
// 弹出栈头两个元素
if len(stack) < 2 {
return 0
}
firstNum := stack[len(stack)-1]
secondNum := stack[len(stack)-2]
stack = stack[:len(stack)-2]
ret := 0
switch token {
case "+":
ret = secondNum + firstNum
case "-":
ret = secondNum - firstNum
case "*":
ret = secondNum * firstNum
case "/":
ret = secondNum / firstNum
}
stack = append(stack, ret)
}
}
return stack[0]
}
func main() {
println("UseCase 1......")
token := []string{"2", "1", "+", "3", "*"}
println(evalRPN(token))
println("UseCase 2......")
token = []string{"4", "13", "5", "/", "+"}
println(evalRPN(token))
println("UseCase 3......")
token = []string{"10", "6", "9", "3", "+", "-11", "*", "/", "*", "17", "+", "5", "+"}
println(evalRPN(token))
}