- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章python利用后缀表达式实现计算器功能由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
本文实例为大家分享了python实现计算器功能的具体代码,供大家参考,具体内容如下 。
运算符在数字的前面 。
1 + (2 + 3) * 4 - 5 (中缀) - + 1 * + 2 3 4 5 (前缀) 。
前缀表达式的计算方法和后缀表达式类似,只是变成了从右往左扫描 。
运算符在中间,运算时需要考虑运算符优先级 。
1+2*3-5 要先算2*3.... 。
运算符在数字的后面,运算时不考虑优先级,只需要遇到符号,就把他前面的两个数字进行运算就好了 。
例如: a b c + + 即: a + (b + c) 。
1 + (2 + 3) * 4 - 5 (中缀) 1 2 3 + 4 * + 5 - (后缀) 。
因为无需考虑优先级,运算是线性结构的,其用栈实现会很简单 。
运算规律,运算数位置不变,改变的是符号的位置 。
2 + 9 / 3 - 5 (中缀) 2 9 3 / + 5 - (后缀) 。
具体方式 。
1.从左到右进行遍历 2.运算数,直接输出. 3.左括号,直接压入堆栈,(括号是最高优先级,无需比较)(入栈后优先级降到最低,确保其他符号正常入栈) 4.右括号,(意味着括号已结束)不断弹出栈顶运算符并输出直到遇到左括号(弹出但不输出) 5.运算符,将该运算符与栈顶运算符进行比较, 如果优先级高于栈顶运算符则压入堆栈(该部分运算还不能进行), 如果优先级低于等于栈顶运算符则将栈顶运算符弹出并输出,然后比较新的栈顶运算符. (低于弹出意味着前面部分可以运算,先输出的一定是高优先级运算符,等于弹出是因为同等优先级,从左到右运算) 直到优先级大于栈顶运算符或者栈空,再将该运算符入栈. **6.*如果对象*处理完毕,则按顺序弹出并输出栈中所有运算符. 。
后缀表达式运算步骤
(以堆栈储存) 从左到右,遇到运算符就弹出相应的运算数,运算后再把结果入栈.最终结果就是栈顶数的值. (由于该运算为线性结构,具体运算时是不需要储存输出后的运算符,一般是输出一个运算符就进行一次运算,不像图中要储存输出状态.) 。
注意点
有时候'-'(负号)是单目运算符,则要修改运算数. 遇到其他运算符(如幂运算)也类似. 。
python代码例子 。
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
|
'''
中缀转换为后缀
'''
a
=
"1+(2+6/1+2)"
#a = "2+9/3-5"
# 可能出现的符号
symbol_1
=
[
'+'
,
'-'
,
'*'
,
'/'
]
symbol_2
=
[
'('
]
symbol_3
=
[
')'
]
# 符号的优先级
priority
=
{
'#'
:
-
1
,
'('
:
1
,
'+'
:
2
,
'-'
:
2
,
'*'
:
3
,
'/'
:
3
}
match_2
=
{
')'
:
'('
}
# 存储符号的栈
zhan
=
[]
zhan.append(
"#"
)
# 结果
result
=
[]
'''
### 这里只是对表达式进行转换
for i in a:
# 如果是数字直接添加到结果
if i.isdigit():
result.append(i)
# 如果是 + - * / 运算,则先出栈更低优先级的,然后入栈
elif i in symbol_1:
# 如果优先级低,则出栈所有优先级>=的符号
while priority[i] <= priority[zhan[-1]]:
result.append(zhan.pop())
# 压入符号
zhan.append(i)
# 如果是左括号,直接压入
elif i in symbol_2:
zhan.append(i)
# 如果是右括号,则出栈,直到遇到了匹配的左括号,然后吧左括号也出栈
elif i in symbol_3:
while zhan[-1] != match_2[i]:
result.append(zhan.pop())
zhan.pop()
result.append(zhan.pop())
print(''.join(result))
'''
# 下面通过将中缀表达式转换为后缀表达式,并进行运算
def
my_operation(symbol, a, b):
a,b
=
int
(a),
int
(b)
if
symbol
=
=
'+'
:
return
a
+
b
elif
symbol
=
=
'-'
:
return
a
-
b
elif
symbol
=
=
'*'
:
return
a
*
b
elif
symbol
=
=
'/'
:
return
a
/
b
def
to_operation(result, zhan):
two
=
result.pop()
one
=
result.pop()
symbol
=
zhan.pop()
ret
=
my_operation(symbol, one, two)
print
(f
"{one}{symbol}{two} = {ret}"
)
result.append(ret)
### 在表达式转换的时候就一边进行了运算
for
i
in
a:
# 如果是数字直接添加到结果
if
i.isdigit():
result.append(i)
# 如果是 + - * / 运算,则先出栈更低优先级的,然后入栈
elif
i
in
symbol_1:
# 如果优先级低,则出栈所有优先级>=的符号
while
priority[i] <
=
priority[zhan[
-
1
]]:
to_operation(result, zhan)
# 压入符号
zhan.append(i)
# 如果是左括号,直接压入
elif
i
in
symbol_2:
zhan.append(i)
# 如果是右括号,则出栈,直到遇到了匹配的左括号,然后吧左括号也出栈
elif
i
in
symbol_3:
while
zhan[
-
1
] !
=
match_2[i]:
to_operation(result, zhan)
zhan.pop()
to_operation(result, zhan)
print
(result)
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://blog.csdn.net/qq_41600708/article/details/113878657 。
最后此篇关于python利用后缀表达式实现计算器功能的文章就讲到这里了,如果你想了解更多关于python利用后缀表达式实现计算器功能的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我目前正在尝试使用 ParaView Calculator-Filter 将给定的笛卡尔坐标 (x,y,z) 转换为球坐标 (r, theta, phi),其中 theta 是极角,phi 是方位角。
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我有这个问题,我想显示如果0/0,输出是:“不能将0除以自身”。如何调整我的代码以便可以显示该输出?如果是这样,我应该使用什么代码才能实现我的目标? 下面是我的代码: #include using
我正在尝试创建一个也支持负数的计算器,并最终创建一个 lisp 风格的树。 我像这样定义词法分析器规则: INT :'-'? [0-9]+ ; LBRACKET : '('; RBRACKET :
我正在开发一个基本的 JavaScript 计算器,我也希望能够开始计算负数。现在,如果我在输入数字之前单击“-”,“-”将不会显示,因此我只能从正数开始。有人可以告诉我如何将其包含在我的代码中吗?
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
这是我第一次尝试 Java。该项目是一个计算器,它需要一个数字、一个运算符(operator)信号(+、-、*、/)和另一个数字来创建方程并给出其最终值,然后询问用户是否要重新启动程序另一个方程或不是
所以我写了这个脚本;它有点像我找到并拼凑起来的计算器的大杂烩。 KeyListener 来自 Java - oracle - .com 网站。顺便说一句,我对此非常陌生,不知道我在做什么。 我正在尝试
我正在尝试创建一个也支持负数的计算器,并最终创建一个 lisp 风格的树。 我像这样定义词法分析器规则: INT :'-'? [0-9]+ ; LBRACKET : '('; RBRACKET :
我正在开发一个基本的 JavaScript 计算器,我也希望能够开始计算负数。现在,如果我在输入数字之前单击“-”,“-”将不会显示,因此我只能从正数开始。有人可以告诉我如何将其包含在我的代码中吗?
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我开始在java中创建一个计算器,我试图循环遍历字符串输入,如果输入中有任何整数,则将它们添加到ArrayList calcOperands中。在 parseInput() 方法中,我使用 charA
我正忙着制作计算器,但不知怎的,整数没有被使用,我不知道为什么。我尝试修复它,但我不知道该怎么做。我使用带有事件的按钮来计算答案,也许有问题。这是我的代码:顺便说一句,我使用 Eclipse
我的主类中有这段代码。我的问题是,GPA 是用总分除以类(class)来计算的。它没有给我完整的号码。 EX,如果总数为 14,类(class)为 4,则为 3.5,我的代码只给我 3.0。有谁知道为
我需要创建一个可以加、减、乘、除、绝对值和舍入的计算器。这是我到目前为止所拥有的 import java.util.Scanner; public class Calculator { pub
我是一名 Java Noob,正在研究 GUI 计算器,但我刚刚来到这里..我已经有了按钮,我需要绑定(bind)这些数字并存储在运算符 ( + - */) 之间的某个位置以显示在我的 JTextAr
这是我的作业。但是,我无法让结果发挥作用。我希望它打印出来为: > 2*7*6 2 * 7 ---- 14 * 6 ---- 84 等等。我希望无论我输入多少个数字,代码都能正常工作
这个问题已经有答案了: What does a "Cannot find symbol" or "Cannot resolve symbol" error mean? (18 个回答) 已关闭 6 年
大家好,感谢您帮助我。 我用 C# 制作了这个计算器,但遇到了一个问题。 当我添加像 5+5+5 这样的东西时,它给了我正确的结果,但是当我想减去两个以上的数字并且还想除或乘以两个以上的数字时,我没有
我一直在开发计算器作为自己的学习项目。它工作正常,只是我无法弄清楚如何阻止人们添加应用程序破坏输入,例如 1++-*/4。我尝试了各种方法,例如将当前显示拆分为一个数组,并将其与具有所有运算符的另一个
我是一名优秀的程序员,十分优秀!