我理解Scanner的优点,以及何时使用Scanner和BufferedReader.
我读了一个不同的,但在一些类似的问题Scanner vs. BufferedReader
当我从输入中读取时,为什么Scanner这么慢?
我认为它与扫描仪中有一个小缓冲区有关,但在这里我迷路了.
原始问题来自,Codechef,但我对该解决方案不感兴趣.
这是一个给定输入的代码示例:
输入:
> 7 3
> 1
> 51
> 966369
> 7
> 9
> 999996
> 1
和代码
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String[] s = br.readLine().split(" ");
int numberOfLines = Integer.parseInt(s[0]);
int divideNumber = Integer.parseInt(s[1]);
int count = 0;
for (int i = 0; i < numberOfLines; i++) {
String number = br.readLine();
if (number.length() < 11) {
int num = Integer.parseInt(number);
if (num % divideNumber == 0) {
count++;
}
}
}
System.out.println(count);
}
}
如果我用扫描仪读取相同的代码,则速度很慢.