东华OJ 基础题75 弟弟的作业

老子叫甜甜 提交于 2020-03-01 03:41:00

问题描述 :
你的弟弟刚做完了“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(),上网搜说类似正则表达式,介绍的一些实例看起来还是很厉害的(我都没用过)
!](https://img-blog.csdnimg.cn/20200229202121579.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NDIwNTQ1MQ==,size_16,color_FFFFFF,t_70)
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;
}

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!