我正在尝试修改此反向抛光表示法计算器。我几乎完成了所有这些,但它不是按照我想要的方式打印,我无法弄清楚原因。源代码是:
def op_pow(stack):
b = stack.pop(); a = stack.pop()
stack.append(a ** b)
def op_mul(stack):
b = stack.pop(); a = stack.pop()
stack.append(a * b)
def op_div(stack):
b = stack.pop(); a = stack.pop()
stack.append(a / b)
def op_add(stack):
b = stack.pop(); a = stack.pop()
stack.append(a + b)
def op_sub(stack):
b = stack.pop(); a = stack.pop()
stack.append(a - b)
def op_num(stack, num):
stack.append(num)
ops = {
'^': op_pow,
'*': op_mul,
'/': op_div,
'+': op_add,
'-': op_sub,
}
def get_input(inp):
tokens = inp.strip().split()
return tokens
def rpn_calc(tokens):
stack = []
table = []
for token in tokens:
if token in ops:
ops[token](stack)
table.append( (token, ' '.join(str(s) for s in stack)) )
else:
op_num(stack, eval(token))
table.append( (token, ' '.join(str(s) for s in stack)) )
return table
rp = rpn_calc(get_input((raw_input())))
print rp
所以,如果我输入:
5 5 +
然后输出是:
[('5', '5'), ('5', '5 5'), ('+', '10')]
理想情况下我希望输出只是:
10
我认为括号可能在那里,因为它在列表中,但我不确定。
谢谢!
答案 0 :(得分:0)
表看起来像存储包含不断变化的状态的列表。而不是从你的rpn_calc函数返回表,听起来你只想返回堆栈的顶部。