用C语言编计算器程序

用C语言编计算器程序,第1张

#include "stdioh"

#include "stringh"

#include "ctypeh"

#include "mathh"

//expression evaluate

#define iMUL 0

#define iDIV 1

#define iADD 2

#define iSUB 3

#define iCap 4

//#define LtKH 5

//#define RtKH 6

#define MaxSize 100

void iPush(float);

float iPop();

float StaOperand[MaxSize];

int iTop=-1;

//

char Srcexp[MaxSize];

char Capaexp[MaxSize];

char RevPolishexp[MaxSize];

float NumCapaTab[26];

char validexp[]="/+-()";

char NumSets[]="0123456789";

char StackSymb[MaxSize];

int operands;

//

void NumsToCapas(char [], int , char [], float []);

int CheckExpress(char);

int PriorChar(char,char);

int GetOperator(char [], char);

void counterPolishexp(char INexp[], int slen, char Outexp[]);

float CalcRevPolishexp(char [], float [], char [], int);

void main()

{

int ilen;

float iResult=00;

printf("enter a valid number string:\n");

memset(StackSymb,0,MaxSize);

memset(NumCapaTab,0,26); //A--NO1, B--NO2, etc

gets(Srcexp);

ilen=strlen(Srcexp);

//printf("source expression:%s\n",Srcexp);

NumsToCapas(Srcexp,ilen,Capaexp,NumCapaTab);

printf("Numbers listed as follows:\n");

int i;

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

printf("%2f ",NumCapaTab[i]);

printf("\nCapaexp listed in the following:\n");

printf("%s\n",Capaexp);

ilen=strlen(Capaexp);

counterPolishexp(Capaexp,ilen,RevPolishexp);

printf("RevPolishexp:\n%s\n",RevPolishexp);

ilen=strlen(RevPolishexp);

iResult=CalcRevPolishexp(validexp, NumCapaTab, RevPolishexp,ilen);

printf("\ncounterPolish expression:\n%s%6f\n",Srcexp,iResult);

}

void iPush(float value)

{

if(iTop<MaxSize) StaOperand[++iTop]=value;

}

float iPop()

{

if(iTop>-1)

return StaOperand[iTop--];

return -10;

}

void NumsToCapas(char Srcexp[], int slen, char Capaexp[], float NumCapaTab[])

{

char ch;

int i, j, k, flg=0;

int sign;

float val=00,power=100;

i=0; j=0; k=0;

while (i<slen)

{

ch=Srcexp[i];

if (i==0)

{

sign=(ch=='-')-1:1;

if(ch=='+'||ch=='-')

{

ch=Srcexp[++i];

flg=1;

}

}

if (isdigit(ch))

{

val=ch-'0';

while (isdigit(ch=Srcexp[++i]))

{

val=val100+ch-'0';

}

if (ch=='')

{

while(isdigit(ch=Srcexp[++i]))

{

val=val+(ch-'0')/power;

power=10;

}

} //end if

if(flg)

{

val=sign;

flg=0;

}

} //end if

//write Capaexp array

// write NOj to array

if(val)

{

Capaexp[k++]='A'+j;

Capaexp[k++]=ch;

NumCapaTab[j++]=val; //A--0, B--1,and C, etc

}

else

{

Capaexp[k++]=ch;

}

val=00;

power=100;

//

i++;

}

Capaexp[k]='\0';

operands=j;

}

float CalcRevPolishexp(char validexp[], float NumCapaTab[], char RevPolishexp[], int slen)

{

float sval=00, op1,op2;

int i, rt;

char ch;

//recursive stack

i=0;

while((ch=RevPolishexp[i]) && i<slen)

{

switch(rt=GetOperator(validexp, ch))

{

case iMUL: op2=iPop(); op1=iPop();

sval=op1op2;

iPush(sval);

break;

case iDIV: op2=iPop(); op1=iPop();

if(!fabs(op2))

{

printf("overflow\n");

iPush(0);

break;

}

sval=op1/op2;

iPush(sval);

break;

case iADD: op2=iPop(); op1=iPop();

sval=op1+op2;

iPush(sval);

break;

case iSUB: op2=iPop(); op1=iPop();

sval=op1-op2;

iPush(sval);

break;

case iCap: iPush(NumCapaTab[ch-'A']);

break;

default: ;

}

++i;

}

while(iTop>-1)

{

sval=iPop();

}

return sval;

}

int GetOperator(char validexp[],char oper)

{

int oplen,i=0;

oplen=strlen(validexp);

if (!oplen) return -1;

if(isalpha(oper)) return 4;

while(i<oplen && validexp[i]!=oper) ++i;

if(i==oplen || i>=4) return -1;

return i;

}

int CheckExpress(char ch)

{

int i=0;

char cc;

while((cc=validexp[i]) && ch!=cc) ++i;

if (!cc)

return 0;

return 1;

}

int PriorChar(char curch, char stach)

{

//栈外优先级高于(>)栈顶优先级时,才入栈

//否则(<=),一律出栈

if (curch==stach) return 0; //等于时应该出栈

else if (curch=='' || curch=='/')

{

if(stach!='' && stach!='/')

return 1;

}

else if (curch=='+' || curch=='-')

{

if (stach=='(' || stach==')')

return 1;

}

else if (curch=='(')

{

if (stach==')')

return 1;

}

return 0;

}

void counterPolishexp(char INexp[], int slen, char Outexp[])

{

int i, j, k,pr;

char t;

i=0;

j=k=0;

while (INexp[i]!='=' && i<slen)

{

if (INexp[i]=='(')

StackSymb[k++]=INexp[i];

//iPush((INexp+i));

else if(INexp[i]==')')

{

//if((t=iPop())!=-1)

while((t=StackSymb[k-1])!='(')

{

Outexp[j++]=t;

k--;

}

k--;

}

else if (CheckExpress(INexp[i])) // is oparator

{

// printf("operator %c k=%d\n",INexp[i],k);

while (k)

{

// iPush((INexp+i));

if(pr=PriorChar(INexp[i],StackSymb[k-1]))

break;

else

{

//if ((t=iPop())!=-1)

t=StackSymb[k-1]; k--;

Outexp[j++]=t;

}

} //end while

StackSymb[k++]=INexp[i]; //common process

}

else //if() 变量名

{

// printf("operand %c k=%d\n",INexp[i],k);

Outexp[j++]=INexp[i];

}

i++; //

}

while (k)

{

t=StackSymb[k-1]; k--;

Outexp[j++]=t;

}

Outexp[j]='\0';

}

C语言编写计算器

我们可以用printf和scanf函数输出结果和获取用户的输入。需要<stdioh>头文件。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 ,这样整个代码就完成了。

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

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

void

main()

{

int

a,b,result;

char

m;

printf("请输入需要计算的数:\n");

scanf("%d

%d",&a,&b);

printf("请输入加、减、乘或除\n");

scanf("%c",&m);

if(m=="+")

//判断是否进行加法运算,以下同理

result=a+b;

else

if(m=="-")

result=a-b;

elsee

if(m=="")

result=ab;

else

if(m=="/")

result=a/b;

else

printf("您输入有误\n");

//如果输入的符号非加减乘或是除,报错

printf("计算结果为:%d\n",result);

//最后输出结果

}

#include<stdioh>

#include<windowsh>

#include<mathh>

#define p 31415926

#define r p/180 //r=p/180,p=314,p/180是求的1弧度,下面sin(里面要求的是弧度),sin(30弧度)=05。 void main()

{

float i,j,k;

int l,m,n,a[10];

char cmd;

LOOP:

system("cls");

printf("\n");

printf("小寒计算器\n");

printf("\n");

printf("\n\n本计算器提供+、-、、/四种运算。\n");

printf("p-代表圆周率pai。\n");

printf("a-代表十进制转换为二进制。\n");

printf("b-代表十进制转换为八进制。\n");

printf("c-代表十进制转换为十六进制。\n");

printf("d-代表该数值开方。\n");

printf("e-代表该数值开立方。\n");

printf("f-代表求几次方。\n");

printf("S-代表sin。\n");

printf("C-代表cos。\n");

printf("T-代表tan。\n");

printf("\n\n请输入要计算的数字和运算符号,输入“#”时,结束;输入“!”时复位。\n");

scanf("%f",&k);

while((cmd=getchar())!='#')

{

if(i!=0)

switch(cmd)

{

case '+': scanf("%f",&i);

k=k+i;

printf("=%52f",k);

break; case '-': scanf("%f",&i);

k=k-i;

printf("=%52f",k);

break; case '': scanf("%f",&i);

k=ki;

printf("=%52f",k);

break; case '/': scanf("%f",&i);

k=k/i;

printf("=%52f",k);

break;

case 'p': k=kp;

printf("%64f",k);

break; case 'f': printf("请输入要求该数字的几次方:");

scanf("%d",&n);

i=k;

for(m=0;m<n-1;m++)

k=ki;

printf("%52f",k);

break; case 'a': printf("转换成二进制\n");

m=0;

while((int)k>0)

{

l=k;

k=k/2;

l=l%2;

a[m]=l;

m++;

}

for(n=m-1;n>=0;n--)

printf("%d",a[n]);

break; case 'b': printf("转换成八进制\n");

m=0;

while((int)k>0)

{

l=k;

k=k/8;

l=l%8;

a[m]=l;

m++;

}

for(n=m-1;n>=0;n--)

printf("%d",a[n]);

break;

case 'c': printf("转换成十六进制\n");

m=0;

while((int)k>0)

{

l=k;

k=k/16;

l=l%16;

a[m]=l;

m++;

}

for(n=m-1;n>=0;n--)

{

if(a[n]==10)

{ printf("A");continue;}

else if(a[n]==11)

{ printf("B");continue;}

else if(a[n]==12)

{ printf("C");continue;}

else if(a[n]==13)

{ printf("D");continue;}

else if(a[n]==14)

{ printf("E");continue;}

else if(a[n]==15)

{ printf("F");continue;} printf("%d",a[n]);

}

break;

case 'e': printf("该数值开立方得\n");

i=pow(k,10/3);

printf("%52f",i );

break;

case 'd': printf("该数值开方得\n");

i=k/2;

j=sqrt(k);

printf("%52f",j);

break; case 'S': k=kr;

i=sin(k);

printf("%52f",i);

break;

case 'C': k=kr;

i=cos(k);

printf("%52f",i);

break; case 'T': k=kr;

i=tan(k);

printf("%52f",i);

break; case '!': goto LOOP;

}

}

}

# include <stdioh>

int main(void)

{

double a, b;

int chose;

printf("欢迎使用我的计算器\n");

while (1)

{

printf("\n");

printf("1、两数相加\n");

printf("2、两数相减\n");

printf("3、两数相乘\n");

printf("4、两数相除\n");

printf("5、退出\n");

printf("\n");

scanf("%d", &chose);

/ if (chose<1 || chose>5)

{

printf("你的输入有误,请重新输入!\n");

continue;

}/

switch (chose)

{

case 1:

printf("请输入第一个数字:\n");

scanf("%lf", &a);

printf("请输入第二个数字:\n");

scanf("%lf", &b);

printf("%lf+%lf = %lf\n", a, b, a+b);

break;

case 2:

printf("请输入第一个数字:\n");

scanf("%lf", &a);

printf("请输入第二个数字:\n");

scanf("%lf", &b);

printf("%lf-%lf = %lf\n", a, b, a-b);

break;

case 3:

printf("请输入第一个数字:\n");

scanf("%lf", &a);

printf("请输入第二个数字:\n");

scanf("%lf", &b);

printf("%lf%lf = %lf\n", a, b, ab);

break;

case 4:

printf("请输入第一个数字:\n");

scanf("%lf", &a);

printf("请输入第二个数字:\n");

scanf("%lf", &b);

printf("%lf/%lf = %lf\n", a, b, a/b);

break;

case 5:

printf("再见!\n");

return  ;

default:

printf("你的输入有误,请重新输入!\n");

continue;

}

}

}

以上就是关于用C语言编计算器程序全部的内容,包括:用C语言编计算器程序、C语言编写简易计算器程序、用C语言编写一个计算器程序,用选择和循环语句,要能够重复连续运算等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/zz/9347945.html

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

发表评论

登录后才能评论

评论列表(0条)

保存