中缀表达式得到后缀表达式(c++、python实现)
将中缀表达式转换为后缀表达式的算法思想如下:
从左往右开始扫描中缀表达式
遇到数字加入到后缀表达式
遇到运算符时:
1、若为‘(’,入栈
2、若为’)‘,把栈中的运算符依次加入后缀表达式,直到出现'(',’(‘出栈,退出该次循环
3、若除’(‘ 和 ‘)’,要入栈的运算符优先级大于等于栈顶的运算符的优先级,直接入栈,否者,栈顶运算符出栈,再次比较,直到出现优先级低的运算符,或者栈为空,退出
中缀表达式为空时,若栈不为空,栈中元素一直出栈,直到栈为空
运算符 ( *,/ +,- )
栈内优先级 1 5 3 6
栈外优先级 6 4 2 1
C++实现如下:
#include <iostream>
#include <algorithm>
#include <string>
#include <stack>
#include <map>
using namespace std; int main()
{
string s_mid="a+b-a*((c+d)/e-f)+g";
string s_beh="";
stack<char> stk;
// stack<char> stk1; map<char,int> op;//利用map来实现运算符对应其优先级
op['(']=;
op[')']=;
op['+']=;
op['-']=;
op['*']=;
op['/']=;
string::iterator it=s_mid.begin();;
while(it!=s_mid.end())
{
if(op.count(*it))//判断该元素是否为运算符
{
if(*it==')')//情况2
{
while(stk.top()!='(')
{
s_beh+=stk.top();
stk.pop();
}
stk.pop();
}
else if(stk.empty()||*it=='('||op[*it]>op[stk.top()])//情况1、情况3
{
stk.push(*it);
}
else if(op[*it]<=op[stk.top()])//情况3
{
while(op[*it]<=op[stk.top()]&&(!stk.empty()))
{
s_beh+=stk.top();
stk.pop();
if(stk.empty()) break;
}
stk.push(*it);
}
}
else
{
s_beh+=*it;
}
it++; // cout<<s_beh<<'\t'; 输出每次结构
// stk1=stk;
// while(!stk1.empty()) 输出栈内情况
// {
// cout<<stk1.top();
// stk1.pop();
// }
// cout<<endl; if(it==s_mid.end())//当中缀表达式输出完成,所有元素出栈
{
while(!stk.empty())
{
s_beh+=stk.top();
stk.pop();
}
break;
}
}
cout<<s_beh<<endl;
return ;
}
python实现如下:
#-*- coding:utf-8 -*- if __name__=='__main__':
s_mid='23/b+(c*d-e*f)/g'
s_beh=''
d={'(':0,')':0,'+':1,'-':1,'*':2,'/':2};
l=[]
while(len(s_mid)):
if s_mid[0] in d.keys():
if s_mid[0]==')':
while True:
if l[len(l)-1]=='(':
break
else:
s_beh+=l.pop()
l.pop()
elif len(l)==0 or s_mid[0]=='(' or d[l[len(l)-1]]<d[s_mid[0]]:
l.append(s_mid[0])
elif d[l[len(l)-1]]>=d[s_mid[0]]:
while d[l[len(l) - 1]] >= d[s_mid[0]]:
s_beh+=l.pop()
if len(l)==0:
break
l.append(s_mid[0])
else:
s_beh+=s_mid[0]
s_mid=s_mid[1:]
if len(s_mid)==0:
while len(l):
s_beh += l.pop()
print s_beh
中缀表达式得到后缀表达式(c++、python实现)的更多相关文章
- ZH奶酪:Python 中缀表达式转换后缀表达式
实现一个可以处理加减乘数运算的中缀表达式转换后缀表达式的程序: 一个输入中缀表达式inOrder 一个输出池pool 一个缓存栈stack 从前至后逐字读取inOrder 首先看一下不包含括号的: ( ...
- 中缀表达式转后缀表达式(Python实现)
中缀表达式转后缀表达式 中缀表达式转后缀表达式的规则: 1.遇到操作数,直接输出: 2.栈为空时,遇到运算符,入栈: 3.遇到左括号,将其入栈: 4.遇到右括号,执行出栈操作,并将出栈的元素输出,直到 ...
- Python与数据结构[1] -> 栈/Stack[1] -> 中缀表达式与后缀表达式的转换和计算
中缀表达式与后缀表达式的转换和计算 目录 中缀表达式转换为后缀表达式 后缀表达式的计算 1 中缀表达式转换为后缀表达式 中缀表达式转换为后缀表达式的实现方式为: 依次获取中缀表达式的元素, 若元素为操 ...
- 利用stack结构,将中缀表达式转换为后缀表达式并求值的算法实现
#!/usr/bin/env python # -*- coding: utf-8 -*- # learn <<Problem Solving with Algorithms and Da ...
- RPN-逆波兰计算器-中缀表达式转后缀表达式-javascript
1.利用栈(Stack)来存储操作数和操作符: 2.包含中缀表达式转后缀表达式的函数,这个是难点,也是关键点: 2.1.将输入字符串转为数组: 2.2.对转换来的字符进行遍历:创建一个数组,用来给存储 ...
- 练习3.20 a 将中缀表达式转换为后缀表达式
//将中缀表达式转换为后缀表达式 int main() { ; ]={,,,,,,,}; char tmp; PtrToStack s; s = CreateStack( MaxSize ); ) { ...
- NYOJ--257--郁闷的C小加(一)(中缀表达式变后缀表达式 )
郁闷的C小加(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...
- .net表达式计算器(中缀表达式转后缀表达式,支持20多个数学函数,支持函数嵌套)
最近在网上查了一下表达工计算器的类库,发现Java版本的有一个比较成熟的叫W3EVal,好像是一个IBM工程师写的,.net就很少了(可能是我了解不够多),但投机取巧的实现思路有很多,比如: (1)将 ...
- hdu-1237 简单计算器---中缀表达式转后缀表达式
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1237 题目大意: 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值. 思路 ...
随机推荐
- Python-分支循环- if elif for while
分支与循环 条件是分支与循环中最为核心的点,解决的问题场景是不同的问题有不同的处理逻辑.当满足单个或者多个条件或者不满足条件进入分支和循环,这里也就说明这个对相同问题处理执行逻辑依据具体参数动态变化, ...
- 用Excel导入Oracle数据库plsql
打开plsql之后,在工具栏点击[tools]--[ODBC Imoprter] 选择导入文件的类型,这里是excel文件,所以选择Excel Files 输入连接数据库的用户名和密码 点击Conne ...
- 安卓----Spinner
<?xml version="1.0" encoding="utf-8"?><FrameLayout xmlns:android=" ...
- 按照excel文档中的内容在当前cad图纸中自动排布实体
本例实现的主要功能是读取excel文档中的内容,其次是将按照读取的信息在当前cad图纸中添加相应的实体.下面先介绍实现代码: CString excelPath; //外部excel文档的地址 Upd ...
- 【NOI赛前训练】——专项测试1·网络流
T1: 题目大意: 传送门 给一个长度为$n(n<=200)$的数列$h$,再给$m$个可以无限使用的操作,第$i$个操作为给长度为花费$c_i$的价值给长度为$l_i$的数列子序列+1或-1, ...
- 【强连通分量】Bzoj1194 HNOI2006 潘多拉的盒子
Description Sulotion 首先要对每对咒语机建图,判断机器a是否能生成所有机器b生成的 如果跑一个相同的串,最后结束的点b可输出a不可输出,判断就为否 大概就用这种思路,f[x][y] ...
- python 防止sql注入字符串拼接的正确用法
在使用pymysql模块时,在使用字符串拼接的注意事项错误用法1 sql='select * from where id="%d" and name="%s" ...
- SprintBoot的@ComponentScan“踩坑”
主要的话说在前面:在启动日志中没有看到Controller对应的URL被映射,那么请检查你的Controller是否被Spring管理了.此次踩坑就是忘了SpringBoot在没配置@Componen ...
- 基于ko-easyui实现的PC前端模板功能完善
上一篇博客我向大家介绍了基于ko-easyui实现的开发模板,博客地址:https://www.cnblogs.com/cqhaibin/p/9825465.html#4095185.但在还遗留三个问 ...
- 史上最最靠谱,又双叒叒简单的基于MSXML的XML解析指南-C++
目录 史上最最靠谱,又双叒叒简单的基于MSXML的XML解析指南 流程设计 xml信息有哪几种读取形式(xml文件或wchar) 如何选取节点,and取节点属性有哪些方法? IXMLDOMNode与I ...