您的位置:首页 > 理论基础 > 数据结构算法

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

2015-11-13 19:12 309 查看


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



Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^


题目描述

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

输入

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

输出

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

示例输入

a*b+(c-d/e)*f#


示例输出

ab*cde/-f*+


提示

来源

示例程序

#include<stdio.h>
int switc(char c)
{
if(c=='+'||c=='-') return 1;
if(c=='*'||c=='/')  return 2;
if(c=='(') return 3;
if(c==')') return 4;
}
int main()
{
int top=0;
char c,b[100];
while(scanf("%c", &c),c!='#')
{
if(c>='a'&&c<='z')
{
printf("%c",c);
}
else
{
if(top==0)
{
top++;
b[top] = c;
}
else
if(switc(c)>=switc(b[top]))
{
if(switc(c) == 4)
{
while(b[top]!='(')
{
printf("%c",b[top--]);
}
top--;
}
else
{
top++;
b[top] = c;
}
}
else
{
if(b[top]!='(')
{
printf("%c", b[top]);
b[top] = c;
}
else
{
top++;
b[top] = c;
}
}

}

}
while(top!=0)
{
printf("%c",b[top]);
top--;
}
printf("\n");return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: