当前位置: 首页 > news >正文

栈的应用——用栈实现算数混合运算表达式的计算

1、单目运算符双目运算符

算数运算符分为单目运算符和双目运算符等
单目运算符只需要一个操作数,双目运算符需要两个操作数

  • 双目运算符最常见:常见的算术运算符:±*/,比较运算符:<>=等等
  • 以下是一些单目运算符:

正号 (+): 用于表示正数或给数值一个正号。例如:+5 仍然是 5。

num = +5
print(num)  # 输出: 5

负号 (-): 用于表示负数或取一个数的相反数。例如:-5 是 -5,而 -(-5) 是 5。

num = -5
print(num)  # 输出: -5
num = -(-5)
print(num)  # 输出: 5

位非运算符 (~): 这是一个按位非运算符,用于对整数的每一位进行取反操作。例如,对于数字 5(其二进制表示为 101),位非运算的结果是 ~101,即 -6。

num = ~5
print(num)  # 输出: -6

需要注意的是,Python中的大多数运算符(如加法、减法、乘法、除法、取模等)都是双目运算符,它们需要两个操作数。而逻辑运算符(如and、or、not)中的not是单目的,但它更常用于逻辑表达式中,而不是直接对单个值进行操作。

2、中缀表达式

两大特点:优先级、结合性
优先级:乘除法>加减法
结合性:优先计算括号内的表达式
中缀表达式交给计算机处理有很大的问题,计算机串行读数据,当遇到运算符时是立即计算还是延期计算
因此引入后缀表达式

3、后缀表达式

中缀表达式:3+4*(5+6)-3
后缀表达式:3456+*+3-
将中缀表达式转化成为后缀表达式有利于计算机处理算数运算

4、栈的应用——中缀转后缀

(1)手算图示

在这里插入图片描述

(2)计算机转化后缀表达式思路:

后缀表达式放在列表中,因为最后要将后缀表达式串行(按照顺序)读,运算符放在栈中,接下来解释过程
1、遇到数字:直接放在列表中
2、遇到符号分情况讨论

  • 当栈为空:压入栈
  • 当运算符优先级高于栈顶运算符:压入栈
  • 遇到左括号,压入栈(括号相当与新的开始,括号后的符号优先级看作全部高于左括号)
  • 遇到右括号,从栈中弹出运算符(append到后缀表达式列表中),直到遇到左括号
  • 当运算符优先级低于或等于栈顶运算符,从栈中弹出运算符(append到后缀表达式列表中)
  • 最后把栈中剩余的运算符弹出,直到栈为空

当然,要先把表达式利用正则表达式拆分,并利用字典定义符号优先级

(3)代码:

  1. 定义栈这样一个数据结构,具体方法如下:
    在这里插入图片描述
class Stack:def __init__(self):self.items = []def push(self, item):self.items.append(item)def pop(self):if not self.is_empty():return self.items.pop()else:return Nonedef peek(self):if not self.is_empty():return self.items[-1]else:return Nonedef is_empty(self):return len(self.items) == 0def size(self):return len(self.items)
  1. 用栈实现转化的代码:

在这里插入图片描述

import re
from stack2 import *precedence = {'(':0,'+': 1, '-': 1, '*': 2, '/': 2, '**': 3}
def infix_to_postfix(expression):output = 
http://www.lryc.cn/news/332298.html

相关文章:

  • 动态规划—机器人移动问题(Java)
  • 第十一届蓝桥杯物联网试题(省赛)
  • 【Python基础教程】5. 数
  • Qt中出现中文乱码的原因以及解决方法
  • Linux 文件相关命令
  • K8S Deployment 简介, 1个简单的Kubernetes Deployment YAML 文件
  • win11安装WSL UbuntuTLS
  • 第十题:金币
  • Windows 11 中Docker的安装教程
  • 纯C代码模板
  • 二、GitLab相关操作
  • 【详细注释+流程讲解】基于深度学习的文本分类 TextCNN
  • Day.21
  • Spring-IoC 基于注解
  • Spring声明式事务以及事务传播行为
  • 【C语言数据库】Sqlite3基础介绍
  • el-upload上传图片图片、el-load默认图片重新上传、el-upload初始化图片、el-upload编辑时回显图片
  • 【拓扑空间】示例及详解1
  • linux安装jdk8
  • Spring重点知识(个人整理笔记)
  • HTML基础知识详解(上)(如何想知道html的全部基础知识点,那么只看这一篇就足够了!)
  • 如何借助Idea创建多模块的SpringBoot项目
  • 爬虫 新闻网站 并存储到CSV文件 以红网为例 V1.0
  • CentOS 使用 Cronie 实现定时任务
  • java生成word
  • C语言中的结构体:揭秘数据的魔法盒
  • Listener
  • 单细胞RNA测序(scRNA-seq)SRA数据下载及fastq-dumq数据拆分
  • 金蝶Apusic应用服务器 未授权目录遍历漏洞复现
  • 成都百洲文化传媒有限公司电商服务的新领军者