使用C语言写的科学计算器,可以实现四则运算、三角函数运算、指对数运算;优先级正确;能智能屏蔽空格,能识别输入错误和运算错误,能实现继续运算、清空运算结果和有效退出的功能
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define INPUT_MAX 1000
#define NODE_MAX 500
#define NUM_OPT 20
#define LEN_OPT 6
#define NUM_OPS 200
typedef enum{
Opd=0,
Opt=1
}Type;
typedef struct{
int opt;
double opd;
Type tp;
}Node;
//括号栈,检测括号是否匹配
char brackets[NUM_OPS];
int bb=0;
int input(Node *in);
int translate(char *p,Node *re,int *len);
double translateopd(char *p,int *len);
int translateopt(char *p,int *len);
int cmp(const char *s,const char *d);
int calculate(Node *n,double *r);
int sclt(int opr,double *opd);
int dclt(int opr,double *opd1,double opd2);
int prid(int c);
/*功能:表达式输入和转换
* 接收输入并翻译为操作符和操作数存入表达式链
*输入:表达式链的地址
*输出:执行状态,正确返回1,错误返回0
*/
int input(Node *in)
{
//input->string
char ins[INPUT_MAX]={0};
int insi=0;
char temp_in=0;
int len=0;
//检测开头的空格
while(' '==(ins[0]=getchar()));
//检测是不是直接输入了一个回车
if(ins[0]!='\n')
{
do{
temp_in=getchar();
//只能忽略多余空格
if(ins[insi]==' '&&temp_in==' ')
continue;
ins[++insi]=temp_in;
}while(temp_in!='\n');
ins[insi]=0;
}
insi=0;
//输入回车直接输出0
if(ins[0]=='\n')
in->tp=Opd,in->opd=0.0,in++;
else
//压入表达式链
while(ins[insi])
{
if(translate(ins+insi,in++,&len))
insi+=len;
else
return 0;
}
//自动添加等号
if((in-1)->opt!='=')
in->opt='=',in->tp=Opt,in++;
in->opt=-1,in->tp=Opt;
return 1;
}
/*功能:翻译字符串为操作数或操作符
*输入:字符串地址,翻译返回节点,操作数和操作符长度返回地址
*输出:翻译结果状态
*/
int translate(char *p,Node *re,int *len)
{
if(*p>='0'&&*p<='9')
{
re->tp=Opd;
re->opd=translateopd(p,len);
return 1;
}
else if(*p==&