python四则运算表达式求值示例详解

 更新时间:2022年07月12日 11:47:21   作者:练习生  
这篇文章主要为大家介绍了python四则运算表达式求值示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

四则运算表达式求值

思路说明

使用双栈来实现——存放数值的栈 nums 与存放运算符的栈 ops.

算法步骤

  • 对原始表达式字符串 exp 进行预处理, 将其转为一个元素对应一个数值或运算符的列表 explist.
  • 遍历 explist , 每个元素依次压入对应的栈中. 每次压入后, 判断当前两栈顶是否可进行乘除运算.栈顶可进行乘除运算的充要条件是, ops 栈顶为<*> ,</> 之一, 且 nums 中的元素比 ops 中的元素恰好多一个. 如果可以运算, 则运算, 并将运算结果压回 nums 中.
  • explist 遍历完之后, 所有乘除运算都已进行, 此时 ops 中只剩加法与减法, 接下来开始另一个循环, 一直运算即可. 最后 nums 中剩余的唯一元素即为表达式的值.

代码

def operation(a, b, op: str):
    """
    计算一次运算的结果
    :param a: val
    :param b: val
    :param op: 运算符
    :return: val
    """
    if op == '+':
        return a+b
    elif op == '-':
        return a-b
    elif op == '*':
        return a*b
    elif op == '/':
        return a/b
    else:
        raise Exception('运算符不正确')
def exp_str2list(exp: str):
    """
    将表达式exp:str转成list,每个元素对应一个数<num>或运算符<op>.
    已知exp是标准的四则运算表达式字符串.
    :param exp: str,表达式
    :return: list
    """
    opset = {'+', '-', '*', '/'}  # 运算符集合
    flag = -1
    explist = list()
    for i, char in enumerate(exp):  # 对表达式字符串中的每个字符
        if char in opset:  # 若char是运算符
            explist.append(exp[flag+1:i])  # 上一个运算符到当前运算符中间为数字,保存到explist
            flag = i  # 更新flag到当前op位置
            explist.append(char)  # 当前op亦加入explist
    explist.append(exp[flag+1:])
    return explist
def calculate_expression(exp: str):
    """
    表达式求值. 计算字符串exp所代表的表达式的值, 返回一个数值
        已知exp是标准的四则运算表达式字符串, 且不含括号.
    :param exp: str, 表达式
    :return: val
    """
    opset = {'+', '-', '*', '/'}
    nums = list()  # 数栈
    ops = list()  # 运算符栈
    explist = exp_str2list(exp)
    print(explist)
    for e in explist:
        # e入栈
        if e in opset:  # 若e是运算符
            ops.append(e)
        else:
            nums.append(eval(e))
        # 若e是优先级高的乘除法, 且
        # nums与ops恰好匹配, 栈顶可以进行一次计算, 运算结果压入回nums
        if ops and ops[-1] in {'*', '/'} and len(nums) == len(ops) + 1:
            op = ops.pop()
            y = nums.pop()
            x = nums.pop()
            nums.append(operation(x, y, op))
    # 此时explist中元素已全部遍历, 同时乘除法均已被运算, 双栈只剩加减法有待运算. 众所周知, 加减法服从结合律, 接下来一路算到底即可.
    while ops:
        op = ops.pop()
        y = nums.pop()
        x = nums.pop()
        x_op_y = operation(x, y, op)
        nums.append(x_op_y)
    return nums[0]
if __name__ == '__main__':
    exp = '1*43+542+532*432'
    print(calculate_expression(exp))
    print(eval(exp))

参考 python开发任意表达式求值全功能示例

以上就是python四则运算表达式求值示例详解的详细内容,更多关于python四则运算表达式求值的资料请关注脚本之家其它相关文章!

相关文章

  • Python matplotlib plotly绘制图表详解

    Python matplotlib plotly绘制图表详解

    plotly本身是个生态非常复杂的绘图工具,它对很多编程语言提供接口。交互式和美观易用应该是 Plotly 最大的优势,而 Matplotlib 的特点则是可定制化程度高,但语法也相对难学,各有优缺点。本文将通过示例详细讲解二者是如何绘制图表的,需要的可以参考一下
    2022-03-03
  • Python制作动态词频条形图的全过程

    Python制作动态词频条形图的全过程

    说起动态图表,最火的莫过于动态条形图了,下面这篇文章主要给大家介绍了关于Python制作动态词频条形图的全过程,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-11-11
  • python 回溯法模板详解

    python 回溯法模板详解

    今天小编就为大家分享一篇python 回溯法模板详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02
  • 一行代码解决动态执行Python函数方法实例

    一行代码解决动态执行Python函数方法实例

    这篇文章主要为大家介绍了如何用一行代码解决动态执行Python函数方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12
  • networkx库绘制带权图给无权图加权重输出

    networkx库绘制带权图给无权图加权重输出

    这篇文章主要为大家介绍了Python networkx库绘制带权图给无权图加权重并输出权重的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • Python学习工具jupyter notebook安装及用法解析

    Python学习工具jupyter notebook安装及用法解析

    这篇文章主要介绍了Python学习工具jupyter notebook安装及用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • Python与HTTP服务交互的三种方式

    Python与HTTP服务交互的三种方式

    本文主要介绍了Python与HTTP服务交互的三种方式,通过http.client,requests,RissionPage,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • Python函数式编程艺术之修饰器运用场景探索

    Python函数式编程艺术之修饰器运用场景探索

    本文将详细介绍Python修饰器的概念,提供详细的示例,并介绍如何使用它们来优化和扩展代码,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • 如何利用python执行txt文件中的代码

    如何利用python执行txt文件中的代码

    这篇文章主要介绍了如何利用python执行txt文件中的代码,python这么强大的语言当然可以做大,只需使用内置的exex()函数,进入主题前我们先来看看什么是exec()函数,需要的小伙伴可以参考一下
    2022-03-03
  • No module named 'plotly.graph_objects'报错解决

    No module named 'plotly.graph_objects&ap

    这篇文章主要为大家介绍了No module named 'plotly.graph_objects'报错解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12

最新评论