数据结构实验之栈与队列二:一般算术表达式转换成后缀式

本文主要是介绍数据结构实验之栈与队列二:一般算术表达式转换成后缀式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据结构实验之栈与队列二:一般算术表达式转换成后缀式

Description
对于一个基于二元运算符的算术表达式,转换为对应的后缀式,并输出之。

Input
输入一个算术表达式,以‘#’字符作为结束标志。

Output
输出该表达式转换所得到的后缀式。

Samples
Sample #1
Input
a*b+(c-d/e)*f#

Output
abcde/-f+

分析:

一般表达式转换后缀式的规则:

   首先,表达式有字母、加减号、乘除号、左括号和右括号组成,理清优先顺序,如果当前操作符大于栈顶操作符,则入栈;若小于,则弹出栈顶操纵符,直至满足入栈要求,或直至栈空字母:不需要入栈,直接输出加减号:优先级小于乘除号,入栈时大于左括号乘除号:优先级最大,入栈时大于左括号左括号:入栈时优先级最高(因为先算括号里面的),所以直接入栈,不需要判断,入栈后优先级最低,等待右括号的到来右括号:作用是弹出栈中遇到左括号之前的所有操作符,然后将左括号pop一下(左括号不能输出)

同级操作符的优先级:

按照运算从左至右的顺序,举个例子:当前判断的元素是’+‘,栈顶元素是’+‘或’-‘,那么栈顶元素需弹出,因为在一般表达式中栈顶元素在当前判断元素的左边,所以先运算

#include<iostream>
#include<stack>
#include<string>
using namespace std;int main()
{stack<char> mystack;string s;cin>>s;for(int i = 0;s[i]!='#';i++){if(s[i]>='a'&&s[i]<='z')cout<<s[i];else if(s[i]=='(')mystack.push(s[i]);else if(s[i]==')'){while(mystack.top()!='('){cout<<mystack.top();mystack.pop();}mystack.pop();}else if(s[i]=='+'||s[i]=='-'){while(mystack.size()!=0&&mystack.top()!='('){cout<<mystack.top();mystack.pop();}mystack.push(s[i]);}else if(s[i]=='*'||s[i]=='/'){while(mystack.size()!=0&&mystack.top()!='('&&(mystack.top()=='*'||mystack.top()=='/')){cout<<mystack.top();mystack.pop();}mystack.push(s[i]);}}while(mystack.size()!=0){cout<<mystack.top();mystack.pop();}return 0;
}

这篇关于数据结构实验之栈与队列二:一般算术表达式转换成后缀式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/718886

相关文章

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

Python在固定文件夹批量创建固定后缀的文件(方法详解)

《Python在固定文件夹批量创建固定后缀的文件(方法详解)》文章讲述了如何使用Python批量创建后缀为.md的文件夹,生成100个,代码中需要修改的路径、前缀和后缀名,并提供了注意事项和代码示例,... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5.

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

hdu1180(广搜+优先队列)

此题要求最少到达目标点T的最短时间,所以我选择了广度优先搜索,并且要用到优先队列。 另外此题注意点较多,比如说可以在某个点停留,我wa了好多两次,就是因为忽略了这一点,然后参考了大神的思想,然后经过反复修改才AC的 这是我的代码 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig