7-2 中缀表达式转换为后缀表达式(C语言)
所谓中缀表达式,指的是运算符处于操作数的中间(例:3 * ( 4 + 2 )),中缀表达式是人们常用的算术表示方法,但中缀表达式不容易被计算机解析,因为既要考虑运算符的优先级,还要考虑括号的处理。但中缀表达式仍被许多程序语言使用,因为它符合人们的普遍用法。后缀表达式,指的是不包含括号,运算符放在两个操作数的后面,所有的计算按运算符出现的顺序,严格从左向右进行(不再考虑运算符的优先规则,也不需要考虑括号)。
给出一个中缀表达式,请将其转换为后缀表达式并输出。
输入格式:
只有一行,是一个长度不超过1000的字符串,表示一个中缀表达式。表达式里只包含±*/与小括号这几种符号。其中小括号可以嵌套使用。运算符、操作数之间用一个空格分隔,数据保证输入的操作数中不会出现负数,保证除数不会为0。
输出格式:
输出对应的后缀表达式。运算符、操作数之间用一个空格分隔,但行尾无多余空格。
输入样例:
3 * ( 4 + 2 )
输出样例:
3 4 2 + *
C实现
#include<stdio.h>
#include<stdlib.h>
typedef struct Node *list;
struct Node{
char data[1001];
int top;//设置为从0~top;top为最后元素下标
};
//入栈;
void push(list s,char ch){
(s->top)++;
s->data[s->top]=ch;
}
//出栈;
char pop(list s){
if(s->top==-1)
return '0';
(s->top)--;
return (s->data[s->top+1]);
}
int main(){
char str[1002];
char ch;
int loc=0;
gets(str);
list ps=(list)malloc(sizeof(struct Node));//存待处理的字符串
ps->top=-1;
while(str[loc]!='\0'){//字符串结尾跳出
ch=str[loc];
//遇到数字打印数字
if(ch>='0'&&ch<='9'){
while(ch!=' '){
printf("%c",ch);
loc++;
ch=str[loc];
//如果结尾为数字
if(str[loc]=='\0')break;
}
printf(" ");
if(str[loc]=='\0')break;
loc++;
ch=str[loc];
}
//处理运算符
if(ch=='('){
push(ps,ch);
}else if(ch=='+' || ch == '-'){
//如果ps栈为空,或遇到(跳出
while(ps->top!=-1 && ps->data[ps->top]!='('){
printf("%c ",pop(ps));
}
push(ps,ch);
}else if(ch == '*' || ch == '/'){
while(ps->top!=-1 && ps->data[ps->top]!='(' && ps->data[ps->top]!='+' && ps->data[ps->top]!='-'){
printf("%c ",pop(ps));
}
push(ps,ch);
}else if(ch==')'){
while(ps->data[ps->top]!='('){
printf("%c ",pop(ps));
}
pop(ps);
}
loc++;
if((str[loc])=='\n')
break;
}
while(ps->top!=-1){
//设置打印格式
if(ps->top==0){
printf("%c",pop(ps));}
else{
printf("%c ",pop(ps));
}
}
return 0;
}
主要思想
这个题的主要思想就是遇到")“括号,就返回找”(",当然要边找边处理括号里的运算符。没遇到就按±*/的优先级输出就可了。
结语
我在开始做这个题时,理解错误。以为要先输出所有数字然后输出所有运算符。后来过不了在网上搜索了一下中缀表达式转换为后缀表达式的格式才恍然。