笔记七(C++中混合四则运算)

这篇笔记主要介绍了如何在C++中进行四则运算表达式的中缀转后缀操作。通过栈的数据结构,遵循特定的转换原则,例如遇到操作数直接输出,遇到右括号时弹出栈中元素直到匹配的左括号等,来实现这一过程。该算法适用于简单的四则运算,不涉及浮点数或复杂表达式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对于简单的四则运算主要算法的实现就是将一个表达式的中缀表达式转换为后缀表达式,这其中应用了栈的后进先出规则;

目的:(转载自 https://blog.youkuaiyun.com/anye3000/article/details/7939203

将中缀表达式(即标准形式的表达式)转换为后缀式。

例子:a+b*c+(d*e+f)*g转换成abc*+de*f+g*+

 

转换原则:

1.当读到一个操作数时,立即将它放到输出中。操作符则不立即输出,放入栈中。遇到左圆括号也推入栈中。

2.如果遇到一个右括号,那么就将栈元素弹出,将符号写出直到遇到一个对应的左括号。但是这个左括号只被弹出,并不输出。

3.在读到操作符时,如果此时栈顶操作符优先性大于或等于此操作符,弹出栈顶操作符直到发现优先级更低的元素位置。除了处理')'的时候,否则决不从栈中移走'('。操作符中,'+' '-'优先级最低,'(' ')'优先级最高。

4.如果读到输入的末尾,将栈元素弹出直到该栈变成空栈,将符号写到输出中。

           注意以下算法只适用于简单的四则运算,对于浮点数和二位数及以上可以利用数组来进行类似编码

#include <iostream>
#include<stack>
#include<deque>
#include<string>
using namespace std;
//C++混合四则运算
int pri(char c)//标识运算符优先级
{
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值