pta编程题 h0105. 弟弟的作业
题目要求
你的弟弟刚做完了“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
代码
C++
#include<iostream>
#include<string>
using namespace std;
int main(){
int a,b,count=0;
char x,y; //符号变量
string c; //答案c可能是问号,应定义为字符型
while(cin>>a>>x>>b>>y>>c){ //判断是否有输入
if(c[0]!='?'){ //判断答案c是否是问好
if(x=='+' && a+b==stoi(c) || x=='-' && a-b==stoi(c)){ //stoi()字符转数字函数
count++; //统计正确个数
}
}
}
cout<<count;
return 0;
}
Java
import java.util.*;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
int count = 0; //统计正确题数
while(sc.hasNext()){ //判断输入
String str = sc.nextLine(); //记录整行输入
boolean bl = verdict(str); //调用判断函数
if(bl){
count++;
}
}
System.out.println(count);
}
public static boolean verdict(String str){ //定义静态boolean返回型函数
String[] str1 = str.split("\\+|\\-|\\="); //以+ - =号分割成3个子串
int a = Integer.valueOf(str1[0]); //类型转换
int b = Integer.valueOf(str1[1]);
String c = str1[2];
if(c.equals("?")){ //判断答案是否是?号
}else{
if(str.contains("+") && a+b==Integer.valueOf(c) || str.contains("-") && a-b==Integer.valueOf(c)){ //contains()函数判断是+法还是-法运算并判断结果是否正确
return true;
}
}
return false;
}
}