自己考研复习的时候,自己动手用C语言写了一点 可以把中缀表达式转为后缀表达式并求值的代码。菜鸟勿喷
写的很简单,只能+-*/ 可以改一下涵盖更多计算
#include<stdio.h>
#include<string.h>
//data top 是用来存储字符 intdata inttop 是存储整数化的数据
typedef struct Stack{
char* data;
int* intdata;
int top;
int inttop;
}Stack;
int main(){
bool InitStack(Stack &s);
bool Pust(Stack &s,char a);
bool Pop(Stack &s,char &e);
Stack CTOB(char a[]);
bool Compute_back(Stack back);
int Yxj(char a);
char string[10]; //中缀表达式
printf("输入中缀表达式\n");
scanf("%s",&string);
Stack back=CTOB(string); //back 为中缀转后缀的栈
printf("%s",back.data);
Compute_back(back);
return 0;
}
bool InitStack(Stack &s){
s.top=-1;
s.inttop=-1;
s.data=new char[20];
s.intdata=new int[20];
}
bool Pust(Stack &s,char a){
if(s.top==20)
return false;
s.top++;
s.data[s.top]=a;
}
bool Pop(Stack &s,char &e){
if(s.