Java - PAT - 1054. 求平均值 (20)
2016-06-20 08:41
357 查看
本题的基本要求非常简单:给定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:
输出样例1:
输入样例2:
输出样例2:
这道题有个细节,需要仔细看题,lz之前做题的时候总是有一个测试点错误,怎么改都不对,找了3个小时的错误才找到,找到的时候真的是奔溃啊,都要吐了,这么小个错误。
注意:1、合法数字个数是0的时候The average of 0 numbers is Undefined
2、合法数字个数是1的时候 要输出The average of 1 number is Y
输入格式:
输入第一行给出正整数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
这道题有个细节,需要仔细看题,lz之前做题的时候总是有一个测试点错误,怎么改都不对,找了3个小时的错误才找到,找到的时候真的是奔溃啊,都要吐了,这么小个错误。
注意:1、合法数字个数是0的时候The average of 0 numbers is Undefined
2、合法数字个数是1的时候 要输出The average of 1 number is Y
import java.util.Scanner; /* * 思路: * 1.因为输入数字不一定是合法的 所以不能用nextDouble(); * 2.所以这里采用字符串输入 * 3.将字符串转变成double型数,如果无法转换(即非法数)则捕捉异常,输出相应语句 * 4.如果该字符串能转变成double型数,则进一步判断是否为合法数(题目规定-1000<=x<=1000 ,并且最多精确到小数点后2位); * 5.这里介绍主要介绍两种判断是否最多是2位小数 * 第一种:将数字转换成精确到2位小数,求与原来的作差的绝对值;如果是0则符合,否则多余2位(该方法不是很严谨)如果输入数据是1.000000则该数字也合法,显然是错误的,但是测试数据没有这类型数据 * 第二种:将字符串长度-“.”的位置-1;即可算出小数点后有几位数字 */ public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); sc.nextLine(); String s = sc.nextLine(); String[] number = s.split(" "); double sum = 0; double counts = 0; for (int i = 0; i < n; i++) { try { double x = Double.parseDouble(number[i]); int times = 0; if (number[i].contains(".")) { times = number[i].length() - number[i].indexOf(".") - 1; } if (x >= -1000 && x <= 1000 && times <= 2 && times >= 0) { sum += x; counts++; } else { throw new Exception(); } } catch (Exception e) { System.out.printf("ERROR: %s is not a legal number\n", number[i]); } } if (counts == 0) { System.out.printf("The average of %.0f numbers is Undefined", counts); } else if (counts == 1) { System.out.printf("The average of %.0f number is %.2f\n", counts, sum / counts); } else { System.out.printf("The average of %.0f numbers is %.2f\n", counts, sum / counts); } } }
相关文章推荐
- java类加载器学习2——自定义类加载器和父类委托机制带来的问题/JAVA类加载的委托模型/Java的委托
- java中的vo,dao
- JAVA工具类( 17) ---properties文件动态修改并自动保存
- 关于eclipse中jar冲突问题(不同版本的jar)
- 使用 Java 开发 OpenCV 应用
- 20145222黄亚奇《Java程序设计》课程总结
- Eclipse_debug (调试) 学习心得
- Java进阶(三)多线程开发关键技术
- Java进阶(三)多线程开发关键技术
- java设计模式(十一)--状态模式
- java错误
- [Java] 类和接口的初始化步骤 - 继承方面
- Java NIO系列教程(二) Channel
- Java NIO系列教程(一) Java NIO 概述
- 十分钟理解 Java 中的动态代理
- 大数乘法[JAVA实现]-经典笔试题
- 回归基础系列-插入排序[JAVA]
- [框架整合]spring+springmvc+mybatis(2)
- 回归基础系列-冒泡排序-[JAVA]
- 回归基础系列-重载与覆盖(重写)[JAVA]