/* 计算器 */

/*  计算器   */

#include<stdio.h>
#include<math.h>
#define max 100
char ex[max];       /*存储后缀表达式*/
void trans(){        /*将算术表达式转化为后缀表达式*/
char str[max];   /*存储原算术表达式*/
char stack[max];       /*作为栈使用*/
char ch;
int sum,i,j,t,top=0;
printf("*****************************************/n");
printf("*输入一个求值的表达式,以#结束。*/n");
printf("******************************************/n");
printf("算数表达式:");
i=0;                      /*获取用户输入的表达式*/
do{
i++;
scanf("%c",&str[i]);
}while(str[i]!='#' && i!=max);
    sum=i;
t=1;i=1;
ch=str[i];i++;
while(ch!='#'){
switch(ch){
case '(':                 /*判定为左括号*/
top++;stack[top]=ch;   /*将'('压入堆栈*/
     break;
        case ')':                 /*判定为右括号*/
while(stack[top]!='('){
                ex[t]=stack[top];top--;t++; /*将'('和')‘之间的算术放入ex数组*/
}
top--;
break;
        case '+':                 /*判定为加减号*/
case '-':      
while(top!=0&&stack[top]!='('){
ex[t]=stack[top];top--;t++; 
}
top++;stack[top]=ch;        /*直接将加减符号压栈*/
break;
case '*':                  /*判定为乘除号*/
        case '/':
while(stack[top]=='*'||stack[top]=='/'){
ex[t]=stack[top];top--;t++;
}
top++;stack[top]=ch;
break;
case ' ':break;
default:while(ch>='0'&&ch<='9'){                 /*判定为数字*/
ex[t]=ch;t++;
ch=str[i];i++;
}
i--;
ex[t]='#';t++;
}
ch=str[i];i++;
}
while(top!=0){
ex[t]=stack[top];t++;top--;
}
ex[t]='#';
printf("/n/t原来表达式:");
for(j=1;j<sum;j++)
printf("%c",str[j]);
    printf("/n/t后缀表达式:",ex);
for(j=1;j<t;j++)
printf("%c",ex[j]);
}
void compvalue(){                                 /*计算后缀表达式的值*/
float stack[max],d;                    /*作为栈使用*/
char ch;
int t=1,top=0;                  /*t为ex下标,top为stack下标*/
ch=ex[t];t++;
    while(ch!='#'){
switch(ch){
  case '+':
  stack[top-1]=stack[top-1]+stack[top];
  top--;
  break;
          case '-':
  stack[top-1]=stack[top-1]-stack[top];
  top--;
  break;
          case '*':
  stack[top-1]=stack[top-1]*stack[top];
  top--;
  break;

          case '/':
          if(stack[top]!=0)
    stack[top-1]=stack[top-1]/stack[top];
          else{
          printf("/n/t除零错误!/n");
          exit(0);                   /*异常退出*/
  }
  top--;
  break;
  default:
  d=0;
  while(ch>='0'&&ch<='9'){
  d=10*d+ch-'0';               /*将数字字符转化为对应的数值*/   
  ch=ex[t];t++;
  }
  top++;
  stack[top]=d;
}
ch=ex[t];t++;
}
printf("/n/t计算结果:%g/n",stack[top]);
}

main(){
trans();
compvalue();
getchar();
getchar();
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值