分享
 
 
 

哪位帮忙用C语言设计一个多功能计算器

王朝知道·作者佚名  2012-09-11
窄屏简体版  字體: |||超大  
 
分類: 電腦/網絡 >> 程序設計 >> 其他編程語言
 
問題描述:

用C语言设计一个多功能计算器

实现功能:

1)具备整型数据、浮点型数据的算术(加、减、乘、除)运算功能。

依次输入第一个运算数、运算符(+,-,*,/),第二个运算数,然后输出结果。

结果可以作为下一个运算的第一运算数。按‘C’清屏,按‘X’退出。

例如:输入:2

+

5

输出:7

2)实现单运算符表达式计算的功能。

输入的操作数可以包含整数或浮点数。如果遇到错误的表达式,应输出错误提示信息。

输入表达式如下:

例如:输入:2+5

输出:7

參考答案:

#include <stdio.h>

#include <stdlib.h>

#include <math.h>

#include <ctype.h>

#include <string.h>

#define MAXOP 100

#define NUMBER '0'

#define MAXVAL 100

#define BUFSIZE 100

#define NAME 'n'

int getop(char s[]);

void push(double);

double pop(void);

int getch(void);

void ungetch(int c);

double atof(char s[]);

void mathfnc(char s[]);

void clear(void);

int sp = 0; double val[MAXVAL];

int bufp = 0; char buf[BUFSIZE];

int main(void)

{

int i, type, var = 0;

double op2, v;

char s[MAXOP];

double variable[26];

for(i = 0; i < 26; i++)

variable[i] = 0.0;

while ((type = getop(s)) != EOF) {

switch(type) {

case NUMBER :

push (atof(s));

break;

case NAME :

mathfnc(s);

break;

case '+' :

push (pop() + pop());

break;

case '*' :

push (pop() * pop());

break;

case '-' :

op2 = pop();

push (pop() - op2);

break;

case '/' :

op2 = pop();

if (op2 != 0.0)

push (pop() / op2);

else

printf ("error: zero divisor\n");

break;

case '%' :

op2 = pop();

if(op2 != 0.0)

push(fmod(pop(), op2));

else

printf("error : zero divisor\n");

break;

case 'c' :

clear();

break;

case '=' :

pop();

if(var >= 'A' && var <= 'Z')

variable[var - 'A'] = pop();

else

printf("error : no variable name\n");

break;

case '\n' :

v = pop();

printf("\t %.8g\n", v);

break;

default :

if(type >= 'A' && type <= 'Z')

push(variable[type - 'A']);

else if (type == 'v')

push(v);

else

printf("error : unknown command %s\n", s);

}

var = type;

}

return 0;

}

/*读入一个数*/

int getop(char s[])

{

int i, c;

while((s[0] = c = getch()) == ' ' || c == '\t') /*去除空格*/

;

s[1] = '\0';

i = 0;

if(c == '-')

if(isdigit(c = getch()) || c == '.')

s[++i] = c;

else {

if(c != EOF)

ungetch(c);

return '-';

}

if(islower(c)) {

while(islower(s[++i] = c = getch()))

;

s[i] = '\0';

if(c != EOF)

ungetch(c);

if(strlen(s) > 1)

return NAME;

else

return c;

}

if(!isdigit(c) && c != '.')/*如果不是数字就返回*/

return c;

if(isdigit(c)) /*读取整数部分*/

while(isdigit(s[++i] = c = getch()))

;

if(c == '.') /*读取小数部分*/

while(isdigit(s[++i] = c = getch()))

;

s[i] = '\0';

if(c != EOF)

ungetch(c); /*把多读入的一个字符返回到输入流*/

return NUMBER;

}

void clear(void)

{

sp = 0;

}

void mathfnc(char s[])

{

double op2;

if(strcmp(s, "sin") == 0)

push(sin(pop()));

else if(strcmp(s, "cos") == 0)

push(cos(pop()));

else if(strcmp(s, "exp") == 0)

push(exp(pop()));

else if(strcmp(s, "pow") == 0) {

op2 = pop();

push(pow(pop(), op2));

}else

printf("error : %s not supported\n", s);

}

void push(double f)

{

if(sp < MAXVAL)

val[sp++] = f;

else

printf("error : stack full, can't pust %g\n", f);

}

double pop(void)

{

if(sp > 0)

return val[--sp];

else {

printf("error: stack empty\n");

return 0.0;

}

}

int getch(void)

{

return ((bufp > 0) ? buf[--bufp] : getchar());

}

void ungetch(int c)

{

if(bufp >= BUFSIZE)

printf("ungetch : too many characters\n");

else

buf[bufp++] = c;

}

double atof(char s[])

{

double val,power;

int i, sign;

for(i = 0; isspace(s[i]); i++)

;

sign = (s[i] == '-') ? -1 : 1;

if(s[i] == '+' || s[i] == '-')

i++;

for(val =0.0; isdigit(s[i]); i++)

val = 10.0 * val + (s[i] - '0');

if(s[i] == '.')

i++;

for(power = 1.0; isdigit(s[i]); i++) {

val = 10.0 * val + (s[i] - '0');

power *= 10.0;

}

return sign * val / power;

}

小贴士:① 若网友所发内容与教科书相悖,请以教科书为准;② 若网友所发内容与科学常识、官方权威机构相悖,请以后者为准;③ 若网友所发内容不正确或者违背公序良俗,右下举报/纠错。
 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有