弟弟的作业
时间限制:1000 ms | 内存限制:65535 KB
难度:1
-
描述
-
你的弟弟刚做完了“100以内数的加减法”这部分的作业,请你帮他检查一下。每道题目(包括弟弟的答案)的格式为a+b=c或者a-b=c,其中a和b是作业中给出的,均为不超过100的非负整数;c是弟弟算出的答案,可能是不超过200的非负整数,也可能是单个字符"?",表示他不会算。
-
输入
- 输入文件包含不超过100行,以文件结束符结尾。每行包含一道题目,格式保证符合上述规定,且不包含任何空白字符。输入的所有整数均不含前导0。 输出
- 输出仅一行,包含一个非负整数,即弟弟答对的题目数量。 样例输入
-
1+2=3
-
3-1=5
-
6+7=?
-
99-0=99
样例输出
-
2
来源
代码实现:
#include<stdio.h>
#include<stdlib.h>
int main()
{
int a,b,c,count=0;
char sign,val[4];
while(~scanf("%d%c%d=%s",&a,&sign,&b,val))
{
c=atoi(val);
if(sign=='+'&&a+b==c)
count++;
else if(sign=='-'&&a-b==c)
count++;
}
printf("%d\n",count);
}
其中用到了#include<stdlib.h>中的atoi函数,atoi (表示 ascii to integer)是把字符串转换成整型数的一个函数,应用在计算机程序和办公软件中。atoi( ) 函数会扫描参数 nptr字符串,跳过前面的空白字符(例如空格,tab缩进等)。
例子如下:
//vs2013里调用printf函数请使用预处理命令#define _CRT_SECURE_NO_WARNINGS
#include <stdlib.h>
#include <stdio.h>
int
main()
{
char
a[] =
"-100"
;
char
b[] =
"123"
;
int
c;
c =
atoi
(a) +
atoi
(b);
printf
(
"c=%d\n"
, c);
return
0;
}
执行结果:c = 23