表达式的转换(0088)

Time limit(ms): 5000
Memory limit(kb): 65535
Submission: 435
Accepted: 93
Accepted

16级卓越班选拔D 14级卓越班选拔D 15级卓越班选拔D

平常我们书写的表达式称为中缀表达式,因为它将运算符放在两个操作数中间,许多情况下为了确定运算顺序,括号是不可少的,而后缀表达式就不必用括号了。后缀标记法:书写表达式时采用运算紧跟在两个操作数之后,从而实现了无括号处理和优先级处理,使计算机的处理规则简化为:从左到右顺序完成计算,并用结果取而代之。例如:8-(3+2*6)/5+4可以写为:8 3 2 6*+5/-4+ 其计算步骤为:

(1):8 3 2 6 * + 5 / -4 +

(2):8 3 12 + 5 / - 4 +

(3):8 15 5 / - 4 +

(4):8 3- 4 +

(5):5 4 +

(6):9

编写一个程序,完成这个转换,要求输出的每一个数据间都留一个空格。

Description

就一行,是一个中缀表达式。输入的符号中只有这些基本符号“0123456789+-*/^()”,并且不会出现形如2*-3的格式。表达式中的基本数字也都是一位的,不会出现形如12形式的数字。所输入的字符串不要判错。

Input

若干个中缀表达式,第I+1行比第I行少一个运算符和一个操作数,最后一行只有一个数字,表示运算结果。运算的结果可能为负数,“/”以整除运算。并且中间每一步都不会超过2^31。

Output

1
8-(3+2*6)/5+4

Sample Input

1
2
3
4
5
6
8 3 2 6 * + 5 / - 4 +
8 3 12 + 5 / - 4 +
8 15 5 / - 4 +
8 3 - 4 +
5 4 +
9

Sample Output

温馨提示:优先级'^'  >  '*'  =  '/'  >  '+'   = ‘-’

分析:(这道题需要中缀转后缀的基础) 有空我再写个中缀转后缀的 详解

这个题变态就变态在 每一步都要输出

所以转换为后缀表达式后还要一步一步处理

由于后缀表达式中既有数字也有字符 所以我采取的方法是 将字符转换为较大的数字 方便处理;

然后就是 后缀表达式的计算  输出 和 更新了。

还是直接贴代码吧;

#include<iostream>
#include<stack>
#include<cmath>
#define INT_MAX 2147483647
using namespace std;
int k,data[];
string str;
int get_priority(const char& x)//获取优先级
{
switch(x)
{
case '+':
case '-': return ;break;
case '*':
case '/': return ;break;
case '^': return ;break;
case '(': return ;break;
case ')': return ;break;
default: return -;
}
}
int convert(const char& x)//将字符转换为较大的整数
{
switch(x)
{
case '+':return INT_MAX-; break;
case '-':return INT_MAX-; break;
case '*':return INT_MAX-; break;
case '/':return INT_MAX-; break;
case '^':return INT_MAX-; break;
}
}
void Cout()//输出处理 要将整数对应的字符转换过来
{
for(int i=;i<k;i++)
{
switch(data[i])
{
case INT_MAX-: cout<<'+'; break;
case INT_MAX-: cout<<'-'; break;
case INT_MAX-: cout<<'*'; break;
case INT_MAX-: cout<<'/'; break;
case INT_MAX-: cout<<'^'; break;
default: cout<<data[i];
}
if(i!=k-)cout<<" ";
}
}
int judge(const int& x) //判断这个较大的数表示的是那个字符
{
switch(x)
{
case INT_MAX-: return ; break;
case INT_MAX-: return ; break;
case INT_MAX-: return ; break;
case INT_MAX-: return ; break;
case INT_MAX-: return ; break;
default: return ;
}
}
void step()//按步计算
{
for(int i=;i<k;i++)
{
if(judge(data[i])!=)
{
switch(judge(data[i]))
{
case :data[i-]=data[i-]+data[i-]; data[i]=data[i-]=INT_MAX; break;
case :data[i-]=data[i-]-data[i-]; data[i]=data[i-]=INT_MAX; break;
case :data[i-]=data[i-]*data[i-]; data[i]=data[i-]=INT_MAX; break;
case :data[i-]=data[i-]/data[i-]; data[i]=data[i-]=INT_MAX; break;
case :data[i-]=pow(data[i-],data[i-]); data[i]=data[i-]=INT_MAX; break;
}
break;
}
}
int t=;
for(int i=;i<k;i++)//更新
{
if(data[i]!=INT_MAX)
data[t++]=data[i];
}
k=t;
}
int main()
{
while(cin>>str)
{
k=; stack<char>q;
for(int i=;i<str.size();i++)
{
if(get_priority(str[i])==-)
{data[k++]=str[i]-''; continue;}
if(q.empty()) q.push(str[i]);
else if(str[i]==')')
{
while(q.top()!='(')
{
data[k++]=convert(q.top()); q.pop();
}
q.pop();
}
else{
while(get_priority(q.top())>=get_priority(str[i])&&q.top()!='('&&!q.empty())
{
data[k++]=convert(q.top()); q.pop(); if(q.empty()) break;
}
q.push(str[i]);
}
}
while(!q.empty())
{
data[k++]=convert(q.top()); q.pop();
}
//前面的都是中缀表达式转后缀表达式的内容;
Cout(); cout<<endl;
while(k>)
{
step();
Cout(); cout<<endl;
}
}
return ;
}

swust oj(0088)表达式的转换的更多相关文章

  1. .Net 中表达式的转换

    .Net 中表达式的转换 如: a>0  && (c>a || a <b ) || (a>b || c>1)    转换后  (((a > 0) a ...

  2. [Swust OJ 404]--最小代价树(动态规划)

    题目链接:http://acm.swust.edu.cn/problem/code/745255/ Time limit(ms): 1000 Memory limit(kb): 65535   Des ...

  3. [Swust OJ 649]--NBA Finals(dp,后台略(hen)坑)

    题目链接:http://acm.swust.edu.cn/problem/649/ Time limit(ms): 1000 Memory limit(kb): 65535 Consider two ...

  4. Python与数据结构[1] -> 栈/Stack[1] -> 中缀表达式与后缀表达式的转换和计算

    中缀表达式与后缀表达式的转换和计算 目录 中缀表达式转换为后缀表达式 后缀表达式的计算 1 中缀表达式转换为后缀表达式 中缀表达式转换为后缀表达式的实现方式为: 依次获取中缀表达式的元素, 若元素为操 ...

  5. 洛谷P1175 表达式的转换

    P1175 表达式的转换 44通过 147提交 题目提供者该用户不存在 标签云端 难度提高+/省选- 时空限制1s / 128MB 提交  讨论  题解 最新讨论更多讨论 这题有毒 抄题解棒责五十! ...

  6. LINQ查询表达式详解(2)——查询表达式的转换

    简介 C#在执行LINQ查询表达式的时候,并不会指定其执行语义,而是将查询表达式转换为遵循查询表达式模式的方法的调用.具体而言,查询表达式将转换为以下名称的调用:Where.Select.Select ...

  7. 中后缀表达式/洛谷P1175 表达式的转换

    P1175 表达式的转换 思路:先用栈转成中缀表达式,再用栈进行计算.要输出过程,因此计算一次输出一次,但是栈没有迭代器,不好用,换成vector(可以pop_back).虽然表达式求值也可以这么做, ...

  8. SWUST OJ NBA Finals(0649)

    NBA Finals(0649) Time limit(ms): 1000 Memory limit(kb): 65535 Submission: 404 Accepted: 128   Descri ...

  9. [Swust OJ 322]--东6宿舍灵异事件(中缀表达式转化为后缀表达式的简单运用)

    题目链接:http://acm.swust.edu.cn/problem/322/ Time limit(ms): 1000 Memory limit(kb): 65535     Descripti ...

随机推荐

  1. 1. Two Sum★

    题目内容:Given an array of integers, return indices of the two numbers such that they add up to a specif ...

  2. Docker笔记二:Lumen & Redis

    Lumen 基于 Laravel 打造,专为构建微服务和 APIs 而生:Redis 与 Memcached 均为常用的 key-value 内存对象缓存服务(系统),免费开源,Redis 支持持久化 ...

  3. 【经验】JavaScript

    1.function closeWin(){             window.open('','_self');       window.opener=null;  //    window. ...

  4. JQuery实现Ajax跨域访问--Jsonp原理

    JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重要的安全性限制,被称为“Same-Origin Policy”(同源策略).这一策略对于Java ...

  5. Java调度框架Quartz简单示例

    Quartz的大名如雷贯耳,这里就不赘述,而且本文也不作为深入探讨,只是看完Quartz的官方文档后,下个简单示例,至少证明曾经花了点时间学习过,以备不时之需. Quartz使用了SLF4J,所以至少 ...

  6. JAVA面试题和答案

    本文我们将要讨论Java面试中的各种不同类型的面试题,它们可以让雇主测试应聘者的Java和通用的面向对象编程的能力.下面的章节分为上下两篇,第一篇将要讨论面向对象编程和它的特点,关于Java和它的功能 ...

  7. Windows7 java-jdk1.7安装及设置变量过程

    jdk安装的次数较少,容易忘记,这里专门记录一下. 1:jdk1.7网上到处都是可以随便下载一个.然后进行安装,不过在安装过程中把安装路径单独记忆一下,在配置变量的时候会用到. 2:安装完JDK后配置 ...

  8. CSS学习之选择器

    html是盖房子,css是将房子装扮的更漂亮一些!CSS(Cascading Style Sheets),值层叠样式表. 语法 选择器 { 属性 : 属性值 ; } 比如, p{color:red;} ...

  9. 【转】SDWebImage实现分析

    该博文来自南峰子的技术博客,文章从下载和缓存俩个大的组件分析到里面一些核心方法的实现,条理清晰,相对于一些一上来就通篇分析实现思路的技术文章, 这篇的讲解思路明确,框架架构也讲的比较清楚.看完这篇再去 ...

  10. windows phone 8.1开发SQlite数据库操作详解

    原文出自:http://www.bcmeng.com/windows-phone-sqlite1/ 本文小梦将和大家分享WP8.1中SQlite数据库的基本操作:(最后有整个示例的源码)(希望能通过本 ...