用c语言编写计算器

用c语言编写计算器,第1张

#include <stdio.h>

struct s_node

{

int data

struct s_node *next

}

typedef struct s_node s_list

typedef s_list *link

link operator=NULL

link operand=NULL

link push(link stack,int value)

{

link newnode

newnode=(link) malloc(sizeof(s_list))

if(!newnode)

{

printf("\nMemory allocation failure!!!")

return NULL

}

newnode->data=value

newnode->next=stack

stack=newnode

return stack

}

link pop(link stack,int *value)

{

link top

if(stack !=NULL)

{

top=stack

stack=stack->next

*value=top->data

free(top)

return stack

}

else

*value=-1

}

int empty(link stack)

{

if(stack==NULL)

return 1

else

return 0

}

int is_operator(char operator)

{

switch (operator)

{

case '+': case '-': case '*': case '/': return 1

default:return 0

}

}

int priority(char operator)

{

switch(operator)

{

case '+': case '-' : return 1

case '*': case '/' : return 2

default: return 0

}

}

int two_result(int operator,int operand1,int operand2)

{

switch(operator)

{

case '+':return(operand2+operand1)

case '-':return(operand2-operand1)

case '*':return(operand2*operand1)

case '/':return(operand2/operand1)

}

}

void main()

{

char expression[50]

int position=0

int op=0

int operand1=0

int operand2=0

int evaluate=0

printf("\nPlease input the inorder expression:")

gets(expression)

while(expression[position]!='\0'&&expression[position]!='\n')

{

if(is_operator(expression[position]))

{

if(!empty(operator))

while(priority(expression[position])<= priority(operator->data)&&

!empty(operator))

{

operand=pop(operand,&operand1)

operand=pop(operand,&operand2)

operator=pop(operator,&op)

operand=push(operand,two_result(op,operand1,operand2))

}

operator=push(operator,expression[position])

}

else

operand=push(operand,expression[position]-48)

position++

}

while(!empty(operator))

{

operator=pop(operator,&op)

operand=pop(operand,&operand1)

operand=pop(operand,&operand2)

operand=push(operand,two_result(op,operand1,operand2))

}

operand=pop(operand,&evaluate)

printf("The expression [%s] result is '%d' ",expression,evaluate)

getch()

}

C语言编写计算器

我们可以用printf和scanf函数输出结果和获取用户的输入。需要<stdio.h>头文件。scanf函数在读取数据的时候不需要再一行上输入每个数据,只要数据和数据之间留出空白就可以了。先声明两个变量number1和number2,operation变量用来存储运算符。用scanf函数获取这两个数字和运算符。分别用%lf %c %lf

请点击输入图片描述

然后需要检测输入是否是正确的,检查是不是+ - * / %,在这里要用到switch函数,用来看operation变量是否别传入了正确的值。

switch(operation)

{

case '+':

printf........

}

具体的运算我们只需要再case之后的printf语句中设定和输出就可以了。

请点击输入图片描述

由于除法和取余运算比较特殊,我们单独说明。除法的除数不能为零,所以除法需要检测除数是否为零,只需要用if else语句就可以,if(number2 == ),取余运算符对于浮点数没有意义,所以将浮点数转换为long类型,强制类型转换,if((long)number2 == 0)   else ,这样整个代码就完成了。

请点击输入图片描述

简单计算器的编辑并不难,但是要注意一些细节,除法的处理要注意除数不能为零的情况,而且取模运算要将两个 *** 作数转化为整型,当然,作为真正的计算器,只实现这些功能是不够的,还需要更多的功能,不过有一个好的开始也不错。

下面我们就运行一下这个程序吧。25*13的值和8%5的值。可以看到是我们期望的值。

请点击输入图片描述

请点击输入图片描述

#include <stdio.h>

struct s_node

{

int data

struct s_node *next

}

typedef struct s_node s_list

typedef s_list *link

link operator=NULL

link operand=NULL

link push(link stack,int value)

{

link newnode

newnode=(link) malloc(sizeof(s_list))

if(!newnode)

{

printf("\nMemory allocation failure!!!")

return NULL

}

newnode->data=value

newnode->next=stack

stack=newnode

return stack

}

link pop(link stack,int *value)

{

link top

if(stack !=NULL)

{

top=stack

stack=stack->next

*value=top->data

free(top)

return stack

}

else

*value=-1

}

int empty(link stack)

{

if(stack==NULL)

return 1

else

return 0

}

int is_operator(char operator)

{

switch (operator)

{

case '+': case '-': case '*': case '/': return 1

default:return 0

}

}

int priority(char operator)

{

switch(operator)

{

case '+': case '-' : return 1

case '*': case '/' : return 2

default: return 0

}

}

int two_result(int operator,int operand1,int operand2)

{

switch(operator)

{

case '+':return(operand2+operand1)

case '-':return(operand2-operand1)

case '*':return(operand2*operand1)

case '/':return(operand2/operand1)

}

}

void main()

{

char expression[50]

int position=0

int op=0

int operand1=0

int operand2=0

int evaluate=0

printf("\nPlease input the inorder expression:")

gets(expression)

while(expression[position]!='\0'&&expression[position]!='\n')

{

if(is_operator(expression[position]))

{

if(!empty(operator))

while(priority(expression[position])<= priority(operator->data)&&

!empty(operator))

{

operand=pop(operand,&operand1)

operand=pop(operand,&operand2)

operator=pop(operator,&op)

operand=push(operand,two_result(op,operand1,operand2))

}

operator=push(operator,expression[position])

}

else

operand=push(operand,expression[position]-48)

position++

}

while(!empty(operator))

{

operator=pop(operator,&op)

operand=pop(operand,&operand1)

operand=pop(operand,&operand2)

operand=push(operand,two_result(op,operand1,operand2))

}

operand=pop(operand,&evaluate)

printf("The expression [%s] result is '%d' ",expression,evaluate)

getch()()

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7831317.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-10
下一篇 2023-04-10

发表评论

登录后才能评论

评论列表(0条)

保存