加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
计算器.cpp 1.64 KB
一键复制 编辑 原始数据 按行查看 历史
yzx 提交于 2019-09-28 22:15 . 上传以前忘上传的:栈计算器
#include<stdio.h>
#include<conio.h>
#include<math.h>
float yunsuan(float front,char p,float next);
int main()
{
float num[30]={0};
char p[30];
int n=0;
float sum=0;
printf("\t\t计算器");
printf("\n\n\n\t 请预先输入运算数个数:");
scanf("%d",&n);
printf("\n\t 请输入(按[Enter]结束):");
for(int i=0;i<n;i++){
char a;
int b[30];
int c=0;
while(1){
a=getch();
if(a>57 || a<48) break;
b[c]=a-48;
printf("%d",b[c]);
c++;
}
for(int j=0;j<c;j++)
num[i]=num[i]+b[j]*pow(10,(c-j-1));
if(a=='.'){
c=0;
printf(".");
while(1){
a=getch();
if(a>57 || a<48) break;
b[c]=a-48;
printf("%d",b[c]);
c++;
}
for(int j=0;j<c;j++)
num[i]=num[i]+b[j]*pow(10,-(j+1));
}
p[i]=a;
printf("%c",p[i]);
}
for(int i=0;i<n;i++){
if(i==0){
sum=num[i];
continue;
}
if((p[i-1]=='+' || p[i-1]=='-') && (p[i]=='*' || p[i]=='/')){
num[i+1]=yunsuan(num[i],p[i],num[i+1]);
p[i]=p[i-1];
continue;
}
sum=yunsuan(sum,p[i-1],num[i]);
}
printf("\n\n\n\t运算结果为:%f\n\n",sum);
return 0;
}
float yunsuan(float front,char p,float next)
{
switch(p){
case '+':
return front+next;
break;
case '-':
return front-next;
break;
case '*':
return front*next;
break;
case '/':
return front/next;
break;
default :
return front;
break;
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化