用竞赛在线评判系统(OJ)编程时,如果要从标准输入(System.in)读入的数据量非常大,使用Scanner类虽然简单,但效率可能偏低,因而可能导致程序超时或内存占用过大。此时可以尝试改用带缓冲的BufferedReader类读取数据以提高效率,而且数据量越大,差异越明显。
需要注意的是,使用字符流BufferedReader从字节流System.in读取数据时,需要先用System.in做参数创建转换流InputStreamReader对象(从字节到字符的桥梁),再用此对象做参数创建BufferedReader对象。
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedReader的readLine()方法和Scanner的nextLine()方法用法类似,都是读取并返回一行String类型字符串,以回车做结束符。当需要从一行字符串中提取基本类型数据时,例如以空格分隔的数组元素,可以先用String类的split(" ")方法将字符串分割成子串数组,再用包装类Integer(或Double)的parseInt()(或parseDouble())方法将每个子串解析为基本类型数据。
BufferedReader rd = new BufferedReader(new InputStreamReader(System.in));
String[] m = rd.readLine().split(" ");
int[] im = new int[5];
for (int i = 0; i < 5; i++){
im[i] = Integer.parseInt(m[i]);
}
for (int t: im) {
System.out.println(t);
}