本题的基本要求非常简单:给定 N 个实数,计算它们的平均值。但复杂的是有些输入数据可能是非法的。一个“合法”的输入是 [−1000,1000] 区间内的实数,并且最多精确到小数点后 2 位。当你计算平均值的时候,不能把那些非法的数据算在内。
输入格式:
输入第一行给出正整数 N(≤100)。随后一行给出 N 个实数,数字间以一个空格分隔。
输出格式:
对每个非法输入,在一行中输出 ERROR: X is not a legal number,其中 X 是输入。最后在一行中输出结果:The average of K numbers is Y,其中 K 是合法输入的个数,Y 是它们的平均值,精确到小数点后 2 位。如果平均值无法计算,则用 Undefined 替换 Y。如果 K 为 1,则输出 The average of 1 number is Y。
输入样例 1:
7
5 -3.2 aaa 9999 2.3.4 7.123 2.35
输出样例 1:
ERROR: aaa is not a legal number
ERROR: 9999 is not a legal number
ERROR: 2.3.4 is not a legal number
ERROR: 7.123 is not a legal number
The average of 3 numbers is 1.38
输入样例 2:
2
aaa -9999
输出样例 2:
ERROR: aaa is not a legal number
ERROR: -9999 is not a legal number
The average of 0 numbers is Undefined
相信这个题很多人都卡在测试点三上了,其实贼简单,一个超级大坑
当count是1的时候,语句中不是numbers而是number!!我大意了啊,没有发现气死了
#include <iostream>
#include <string>
#include<algorithm>
#include<bits/stdc++.h>
#include<stack>
#include<set>
#include <vector>
#include <map>
#include<queue>
#include<deque>
#include<cctype>
#include<unordered_set>
using namespace std;
int main(){
int n;
cin>>n;
int count=0;
double sum=0;
while(n--){
string s;
cin>>s;
int count2=0;
int flag=0;
for(int i=0;i<s.size();i++){
if(s[i]=='-'&&i==0){
continue;
}
if(s[i]=='.'){
count2++;
}
if(!isdigit(s[i])&&s[i]!='.'){
flag=1;
cout<<"ERROR: "<<s<<" is not a legal number"<<endl;
break;
}
}
if(flag){
continue;
}
if(count2>1){
cout<<"ERROR: "<<s<<" is not a legal number"<<endl;
continue;
}
int pos=s.find(".");
if(pos!=-1){
if(pos==0){
cout<<"ERROR: "<<s<<" is not a legal number"<<endl;
continue;
}
string s1=s.substr(pos);
if(s1.size()>3){
cout<<"ERROR: "<<s<<" is not a legal number"<<endl;
continue;
}
}
if(stod(s)<-1000||stod(s)>1000){
cout<<"ERROR: "<<s<<" is not a legal number"<<endl;
continue;
}
count++;
sum+=stod(s);
}
if(count){
if(count==1){
cout<<"The average of "<<count<<" number is ";
printf("%.2f",sum/count);
}
else {
cout<<"The average of "<<count<<" numbers is ";
printf("%.2f",sum/count);
}
}
else{
cout<<"The average of "<<count<<" numbers is Undefined";
}
return 0;
}