修改反向抛光符号计算器?

时间:2013-11-13 14:20:52

标签: python python-2.7

我正在尝试修改此反向抛光表示法计算器。我几乎完成了所有这些,但它不是按照我想要的方式打印,我无法弄清楚原因。源代码是:

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

我认为括号可能在那里,因为它在列表中,但我不确定。

谢谢!

1 个答案:

答案 0 :(得分:0)

表看起来像存储包含不断变化的状态的列表。而不是从你的rpn_calc函数返回表,听起来你只想返回堆栈的顶部。