算数表达式求值(C语言)

算数表达式求值(C语言)_第1张图片



#include
#include
#define SIZE 50
typedef int DATA;
#include"SeqStack.h"//顺序栈 

int IsOperator(char c)//判断是否为运算符,是返回1,否返回0 
{
	switch(c)
	{
		case '+':
		case '-':
		case '*':
		case '/':
		case '(':
		case ')':
		case '=':
			return 1;
			break;	
		default:
			return 0;
			break;
	} 
}

int PRI(char oper1,char oper2)//判断两个运算符的优先级
//oper1>oper2 返回1;    oper1oper2
			else pri=-1;
			break; 
		case '(':
			if(oper1==')')//'('右侧不能马上出现')' 
			{
				printf("wrong!!\n");
				exit(0);
			}
			else pri=-1;
			break;
		case ')':
			if(oper1=='=')
				{
					printf("括号不匹配\n");
					exit(0);
				}
			else if(oper1=='(')pri=0;
			else pri=1;
			break;
		case'=':
			if(oper1=='(')
			{
				printf("括号不匹配\n");
				exit(0);	
			}
			else if(oper1=='=')
				pri=0;  //等号配对返回0
			else pri=1;
			break; 
	}
	return pri;///////////////////误删导致运行卡住////////////////////////////////////			
}
int Calc(int a ,int oper,int b)//计算两个操作数的结果 
{
	switch(oper)
	{
		case'+':return a+b;
		case'-':return a-b;
		case'*':return a*b;
		case'/':
			if(b!=0)return a/b;
			else 
			{
				printf("分子不能为0!\n");
				exit(0);
			}
	}	
}


int CalcExp(char exp[])
{
	SeqStack *StackOper,*StackData;
	int i=0,flag=0;
	//flag用以处理多位数,while中每次从表达式中取一个字符,flag=0时:操作数已入栈;flag=1时:有操作数要入栈 
	DATA a,b,c,q,x,t,oper;//q用来保存多位操作数 
	 
	StackOper=SeqStackInit();//初始化栈 
	StackData=SeqStackInit();
	
	q=0;
	x='=';//'='作为表达式的第一位运算符入栈 
	SeqStackPush(StackOper,x);//"=" 进操作符栈
//	x=SeqStackPeek(StackOper);/////////////////////////////////////////////////////
	
	c=exp[i++];//从字符串中获取第一个字符 c=exp[0],i=1
	while (c!='='||x!='=')//遍历表达式的每一个字符,直到'=' ;  x:栈顶字符  ; c:当前运算符 
	{
		if(IsOperator(c))//是操作符时 
		{
			if(flag){//将之前的(多位)操作数q入栈 
				SeqStackPush(StackData,q);
				q=0;
				flag=0;//操作数已入栈
			} 
			switch(PRI(x,c)){
				case -1://xc 			
					oper=SeqStackPop(StackOper);//运算符出栈 
					b=SeqStackPop(StackData);//后 操作数出栈 
					a=SeqStackPop(StackData);//前 
					t=Calc(a,oper,b);
					SeqStackPush(StackData,t);//运算结果入栈 
					break;
			}			
		}
		else if(c>='0'&&c<='9')	//字符在'0'到'9'之间 多位数处理
		{
			c-='0';//字符转化成相应数值
			q=q*10+c;//多位数进位 
			flag=1;
			c=exp[i++];//取表达式下一个字符 
		}
		else {
			printf("input wrong!\n");
			getch();
			exit(0);
		}
		x=SeqStackPeek(StackOper);//获取栈顶运算符 
	} 

	q=SeqStackPop(StackData);
	SeqStackFree(StackOper);
	SeqStackFree(StackData);
	return q;
}
int main()
{
	int c;
	char exp[80];
	printf("请输入要计算的表达式(以=结束):");
	scanf("%s",exp);
	printf("%s%d\n",exp,CalcExp(exp));
	getch();
	return 0;
}	
	 


你可能感兴趣的:(数据结构,C语言,算法)