c语言 表达式求值

描述有t组测试数据,每组数据只有一行,即一个不含括号且只有加减法的正整数表达式。你需要编写一个程序,计算出此表达式的值关于输入第一行为t,表示共有t(t<20)个测试样例... 描述
有t组测试数据,每组数据只有一行,即一个不含括号且只有加减法的正整数表达式。你需要编写一个程序,计算出此表达式的值

关于输入
第一行为t,表示共有t (t < 20) 个测试样例。每个测试样例只含一行,即一个不含括号且只有加减法的正整数表达式。表达式中每个整数的值大于0小于1000,且至少包含一个运算符。每行输入的字符个数不大于200。

关于输出
按如下格式,输出每个表达式的值。

例子输入
2
1+2
5-3+1-5+1

例子输出
Case 1:
1+2=3

Case 2:
5-3+1-5+1=-1

提示
stdlib.h中有一个函数atoi, 可以把一个只含整数的字符串转为一个int型的整数。
原型 int atoi(const char *nptr)
展开
 我来答
cdyzxy
推荐于2017-10-15 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.4万
采纳率:85%
帮助的人:3700万
展开全部
#include<stdio.h>
#inlcude<stdlib.h>
void main()
{
char str[20][201],*p0,*p1;
int t,i,s,f,loop;
scanf("%d",&t); if ( t>20 ) t=20;
for ( i=0;i<t;i++ ) scanf("%s",str[i]);
for ( i=0;i<t;i++ )
{ p0=p1=str[i]; s=0; f=1; loop=1;
while ( loop )
{ while ( (*p1)>='0' && (*p1)<='9' ) p1++;
s+=(f*atoi(p0));
switch ( (*p1) )
{ case 0: loop=0; break;
case '+': f=1; break;
case '-': f=(-1); break;
default: loop=0; break;
}
p1++; p0=p1;
}
printf("\nCase %d:\n",i+1);
printf("%s=%d\n",str[i],s);
}
}
kaixingui2012
2015-01-05 · TA获得超过4.2万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:6377万
展开全部
1、先取第一个数(遇到符号止)
2、记录当前符号
3、取下一个数(遇到符号止)
4、前两数按上次记录符号运算,结果存到第一个数上
5、重复2-4,直到取下一数时,遇到字符串结束符为止
追问
求具体代码
追答
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式