1054 求平均值

本题的基本要求非常简单:给定 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   题解:这道题要注意,首先满足以下几种情况就是错误数据
  1.由字母组成或者包含字母。
  2.有两个或两个以上的小数点。
  3.数据超过[-1000,1000]范围。
  我们需要对每个数据进行判断,如果不是错误数据,将其加到总数上并在正确数据个数上加一即可。最后进行输出,输出时注意当正确个数为1时的情况。
  知识点复习:
  ①atof包含在头文件#include <stdlib.h>下,用于将字符串转化为浮点数,(只能处理char数组,不可以处理string串)。
  ②使用string的话,可以借助stringstream来实现字符串到浮点数的操作,stringstream包含在#include<sstream>下,每次使用前记得要使用.clear()清空流的错误标记,并且用.str()方法赋值。(现在感觉stringstream是真的好用,可以实现字符串到int,字符串到double的转换,还可以用流的方式给字符串赋值。)
  ③也可以使用sscanf() 和sprintf()进行这个转换操作,时间有点晚,明天给你们接着写这个。
代码如下:
 #include<iostream>
#include<string>
#include<sstream>
using namespace std; int main()
{
int num, N, k = ;
double sum = , y;
string a;
stringstream ss;
scanf("%d",&N);
while(N--){
bool flag1 = true, flag2 = false;
cin>>a;
int num2 = , num3 = ;
for( int i = ; i < a.length(); i++){
if( (a[i] < '' || a[i] > '') && a[i] != '.' && a[i] != '-' ){
flag1 = false;
break;
}
if(flag2)
num2++;
if( num2 > ){
flag1 = false;
break;
}
if( a[i] == '.' ){
flag2 = true;
num3++;
}
if(num3 > ){
flag1 = false;
break;
}
}
ss.clear();
ss.str(a);
ss>>y;
if(!flag1 || ( y > || y < - )){
cout<<"ERROR: "<<a<<" is not a legal number\n";
continue;
}
sum += y;
k++;
}
if(k==)
cout<<"The average of 0 numbers is Undefined";
else if(k>){
cout<<"The average of "<<k<<" numbers is ";
printf("%0.2lf",sum/k);
}
else if( k == ){
cout<<"The average of 1 number is ";
printf("%0.2lf",sum);
}
return ;
}

最新文章

  1. Google protobuf proto文件编写规则
  2. Nim教程【十一】
  3. NYOJ:题目490 翻译
  4. VMware ESXI磁盘下载虚拟机迁移到另一台VMware ESXI
  5. atitit.gui界面纵向居中总结
  6. PHP 500 -Invalid command RewriteEngine的解决
  7. 单选按钮选中js的处理
  8. PYTHON多进程编码结束之进程池POOL
  9. Temporary ASP.NET Files 文件夹中保存的是什么内容?[转]
  10. Nginx 负载均衡-加权轮询策略剖析
  11. 一篇文章为你深度解析HTTPS 协议
  12. 【Maven】添加ueditor到maven本地仓库
  13. 解决Windows10或者其他版本Windows Update报错的问题
  14. R和Tableau平行坐标图
  15. leecode第六十一题(旋转链表)
  16. SQL Prompt 智能提示插件
  17. Tomcat 环境变量配置
  18. p2p状态码
  19. C#实现字符串计算
  20. CF993E Nikita and Order Statistics 【fft】

热门文章

  1. Points on Plane Codeforces - 576C
  2. linux下svn服务器搭建步骤
  3. 安装linux时的分区问题,需要了解目录树及挂载知识
  4. onpageshow 监听页面是否是缓存页面
  5. jquery测试解析
  6. 实现如下语法的功能:var a = add(2)(3)(4)
  7. nodejs中的异步回调机制
  8. 深刻的理解Fragment生命周期 都在做什么,fragment生命周期
  9. uvm_scoreboard——得分
  10. import 何时使用 &quot;&quot; 和&lt;&gt; Objective-C