c语言中栈二元运算符,栈实现表达式计算(C语言)

#include

#include

#include

#include

#define stacksize 100

typedef char datatype;

typedef int datamath;

typedef struct{

datatype data[stacksize];

int top;

}seqstack;

void initstack(seqstack *s){

s->top=0;

}

int stackempty(seqstack *s){

return s->top==0;

}

int stackfull(seqstack *s){

return s->top==stacksize;

}

void push(seqstack *s,datatype

x){

if(stackfull(s))printf("full \n");

s->data[s->top]=x;

++s->top;

}

datatype pop(seqstack *s){

if(stackempty(s))printf("no data!");

s->top--;

return s->data[s->top];

}

datatype stacktop(seqstack

*s){

if(stackempty(s))printf("no data!");

return s->data[s->top-1];

}

typedef struct{

datamath data[stacksize];

int top;

}mathstack;

void initstack2(mathstack

*s){

s->top=0;

}

int stackempty2(mathstack

*s){

return s->top==0;

}

int stackfull2(mathstack

*s){

return s->top==stacksize;

}

void push2(mathstack *s,datamath

x){

if(stackfull2(s))printf("full \n");

s->data[s->top]=x;

++s->top;

}

datamath pop2(mathstack *s){

if(stackempty2(s))printf("no data!");

s->top--;

return s->data[s->top];

}

datamath stacktop2(mathstack

*s){

if(stackempty2(s))printf("no data!");

return s->data[s->top-1];

}

int fuhaoweizhi(char ysf){

switch(ysf){

case '+':return 0;

case '-':return 1;

case '*':return 2;

case '^':return 3;

case '(':return 4;

case ')':return 5;

case '#':return 6;

default:return 9;

}

}

char panduan(char zhanding,char

jingzhan){

char

a[7][7]={{'>','>','','>'},

{'>','>','','>'},

{'>','>','>','','>'},

{'>','>','>','>','','>'},

{'

{'>','>','>','>','a','>','>'},

{'

int m,n;

m=fuhaoweizhi(zhanding);

n=fuhaoweizhi(jingzhan);

return a[m][n];

}

int yunsuan(int first,int

second,char yunsuanfu){

double

f,s;

if(yunsuanfu=='+'){return first+second;}

else

if(yunsuanfu=='-'){return first-second;}

else

if(yunsuanfu=='*'){return first*second;}

else

if(yunsuanfu=='^'){

f=(double)(first);

s=(double)(second);

return (int)(pow(f,s));

}

}

void main(){

seqstack oper;

mathstack shu;

char *a;

char b[20];

int results;

char pd;

char yusuanf;

int qq=0;

int sec,fir;

int jg;

initstack(&oper);

initstack2(&shu);

printf("enter please:");

scanf("%s",b);

a=b;

while(*a){

if(!((*a)>='0'&&(*a)<='9')){

if(stackempty(&oper)){push(&oper,*a);}

else{

pd=panduan(stacktop(&oper),*a);

if(pd=='>'){

yusuanf=pop(&oper);

sec=pop2(&shu);

fir=pop2(&shu);

push2(&shu,yunsuan(fir,sec,yusuanf));

a--;

}

else

if(pd=='

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值