C语言表达式计算器
为了方便了解流程,在程序中把计算过程也输出了.而且栈操作的实现部分也是自己实现的.程序用两个栈,optr寄存运算符,opnd寄存操作数和运算结果.输入的表达式以等号结束,例如:2*(1+2)=
/**************表达式计算器************/
#include <stdio.h>^"b~)nf{
#include <stdlib.h>
#include <string.h>gcKo,]R j#?J|n
#include <conio.h>+WG~9f*HEV
#include <malloc.h>a.kY5h'gR-o
.wL-Zn*iuZs
#define STACK_SIZE 100@yM2o(Fz5F
#define APPEND_SIZE 10)_/n#xK?r
6Y;@8Zg(zs^?m~
struct SNode{R(_.jy\u
float data; /*存放操作数或者计算结果*/
char ch; /*存放运算符*/8KLY |3S*H)I
};(sWG/kqf&XP@
JDUNW1{@8kC
struct Stack{
SNode *top;;Nox!v2^)B:wS8j9W
SNode *base;
int size;4`(E5g.a|%B U7}8@
};
.v6phy'J
/*栈操作函数*/
int InitStack(Stack &S); /*创建栈*//Z#]&x\6`!p0vY0N+\M1H
int DestroyStack(Stack &S); /*销毁栈*/
int ClearStack(Stack &S); /*清空栈*/
int GetTop(Stack S, SNode &e); /*取出栈顶结点并返回节点值*/
int Push(Stack &S,SNode e); /*将结点e压入栈*/
int Pop(Stack &S,SNode &e); /*删除栈顶结点并返回其节点值*//hUaT[O)T
5zm(w'X[ E
/*表达式计算器相关函数*/
char get_precede(char s,char c); /*判断运算符s和c的优先级*/-V"].K(h}j,z^x
int isOpr(char c); /*判断输入的字符是不是运算符,是则返回0,否返回1*/
float operate(float x, char opr, float y); /*计算x和y经过运算符opr计算后的结果*/
float compute(); /*表达式结算器主函数*/
char *killzero(float result); /*去掉结果后面的0*/
e9K-P3CT
int InitStack(Stack &S)
{
S.base=(SNode *)malloc(STACK_SIZE * sizeof(struct SNode));
if(S.base==NULL)/I*zY;Y3d$K_
{1U)oHvrX,@l
printf("动态分配内存失败!"); yo$P#s+F9j(V#G
return -1;S7T$Gm R*}1my
}
S.top=S.base; k(q dB({.Uy-_w4Wo*S
S.size=STACK_SIZE;4UA'C)S#@$m1v
return 0;.t)u'qTc%@6H2e
}SA7c7[t ~S2a-k
int DestroyStack(Stack &S)
{
free(S.base);z-YUb7~/|-`'a VQ-e
return 0;
}
J$iiOn9}
int ClearStack(Stack &S)