问题描述 :
你的弟弟刚做完了“100以内数的加减法”这部分的作业,请你帮他检查一下。每道题目(包括弟弟的答案)的格式为a+b=c或者a-b=c,其中a和b是作业中给出的,均为不超过100的非负整数;c是弟弟算出的答案,可能是不超过200的非负整数,也可能是单个字符"?",表示他不会算。
输入说明 :
输入文件包含不超过100行,以文件结束符结尾。每行包含一道题目,格式保证符合上述规定,且不包含任何空白字符。输入的所有整数均不含前导0。
输出说明 :
输出仅一行,包含一个非负整数,即弟弟答对的题目数量。
输入范例 :
55+12=67
15-8=7
100-35=?
83-50=33
4-3=6
81+5=21
输出范例 :
3
总结
1.这道题看起来很简单,嗯…,这里在书上看到了stdio.h里面的函数,除了gets和puts,还有其他用于字符串输入输出的函数
sprintff()、sscanf(),上网搜说类似正则表达式,介绍的一些实例看起来还是很厉害的(我都没用过)
2.还有个函数在书上找的strchr(数组名。‘要寻找的字符’),在指定字符串中查找指定字符,若找到,函数返回该字符第一次出现的内存位置,否则返回0;这样一来我很快就能找到是否含有‘?’,太含有技术量了,可能我自己在考场上就想不起来用这招
#include<stdio.h>
#include<ctype.h>
#include<string.h>
int main(){
int op1,op2,answer,res,count;
char ch1,ch2;
char str[100];
count=0;
while(scanf("%s",&str)!=EOF){
if(strchr(str,'?')==0){
sscanf(str,"%d%c%d%c%d",&op1,&ch1,&op2,&ch2,&res);
if(ch1=='+'){
answer=op1+op2;
}
if(ch1=='-'){
answer=op1-op2;
}
if(answer==res)
count++;
}
}
printf("%d\n",count);
return 0;
}
来源:CSDN
作者:韩豆豆小姐
链接:https://blog.csdn.net/weixin_44205451/article/details/104580824