本题的基本要求非常简单:给定 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
思路
用到了格式化输入和输出函数
sscanf(const char* str,"格式",目标地址);
sprintf(const char* str,"格式",目标);
先输入a字符串 然后从字符串中提取%lf类型数据到变量c中 , 再将变量c格式化输出到b字符串中
此时比较a与b的每个字符是否相同 以a字符串的长度为遍历终止 因为当输入5时候 b为5.00此时
a等与b第一个字符合法 输入5.0时 b为5.00依旧合法
#include<bits/stdc++.h>
using namespace std;
int main() {
int n, cou = 0;
cin >> n;
double sum, c;
char a[50], b[50];
//b数组初试化为\0
memset(b, '\0', sizeof(b));
for (int i = 0; i < n; ++i) {
bool flag = true;
cin >> a;
//将a格式化提取到c
sscanf(a, "%lf", &c);
//将c保留两位小数输出到b
sprintf(b, "%.2lf", c);
//判断是否尾数多了 是不是纯数字
for (int j = 0; j < strlen(a); ++j)
if (a[j] != b[j])
flag = false;
//判断c大小是否合法
if (c > 1000 || c < -1000)
flag = false;
if (!flag)
printf("ERROR: %s is not a legal number\n", a);
else {
sum += c;
++cou;
}
}
if (cou == 1)
printf("The average of 1 number is %.2f\n", sum);
else if (cou > 1)
printf("The average of %d numbers is %.2f\n", cou, sum /= cou);
else
printf("The average of 0 numbers is Undefined\n");
return 0;
}