返回:计算结果
C代码如下:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<ctype.h>//包含isdigit函数
#define MAX 100
int calculate(int len, char* expStr);
int main()
{
char *str = (char*)malloc(2*MAX*sizeof(char));
int len;
printf("please input the expr:");
scanf("%s",str);
len = strlen(str);
printf("after calculation, the result is: %d\n", calculate(len,str));
return 0;
}
int calculate(int len, char* expStr)
{
char operation[MAX];
int number[MAX];
int op_index = 0;
int num_index = 0;
int i;
for(i=0; i<len; i++)
{
if(isdigit(*(expStr+i)))//如果是数字,则进入数字数组
{
number[num_index] = *(expStr+i) - '0';
num_index++;
continue;
}
if(*(expStr+i) == '*')//如果是乘法,可以先计算出其左右两数之乘积
{
number[num_index-1] *= (*(expStr+i+1)-'0');
i++;//因为已经将乘号右边的数取出来了
continue;
}
if(*(expStr+i) == '/')//如果是除法,可以先计算其左右两数之商
{
if(*(expStr+i+1) == '0')
{
printf("Error: 0 can not be the divisor!\n");
exit(1);
}
else
{
number[num_index-1] /= (*(expStr+i+1)-'0');
i++;//因为已经将除号右边的数取出来了
continue;
}
}
if(*(expStr+i) == '+' || *(expStr+i) == '-')//对于加减法,则需要进入符号数组
{
operation[op_index] = *(expStr+i);
op_index++;
continue;
}
}
/*
如果符号数组中有n个符号,则数字数组中一定有n+1个数字,
并且如果一个符号在符号数组中的索引为i,
则该符号对应的第二个操作数一定在数字数组中的第i+1个位置。
*/
for(i=0; i<op_index; i++)
{
if(operation[i] == '+')
{
number[0] += number[i+1];
continue;
}
else
{
number[0] -= number[i+1];
continue;
}
}
return number[0];
}
原文地址:http://blog.csdn.net/hs794502825/article/details/37997071