BufferedReader比Scanner要快
  TEZNKK3IfmPf 2024年03月29日 23 0

Reader和Scanner比较

BufferedReader是支持同步的,而Scanner不支持。BufferedReader的read函数都加了synchronized关键字

BufferedReader的缓冲区大小为8KB,Scanner的缓冲区大小为1KB

BufferedReader相对于Scanner来说要快一点,因为Scanner对输入数据进行正则解析,而BufferedReader只是简单地读取字符序列。

BufferedReader比Scanner要快

java解题代码:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.HashMap;
import java.util.Map;

public class Main {
    public static void main(String[] args) throws IOException {
        Map<String, String> map = new HashMap<String, String>();
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int n = Integer.parseInt(br.readLine());
        for (int i = 0; i < n; ++i) {
            String str = br.readLine();
            String[] arr = str.split(" +");
            map.put(arr[1], arr[0] + " " + arr[2]);
        }
        int t = Integer.parseInt(br.readLine());
        String[] sarr = br.readLine().split(" +"); 
        br.close();
        for (int i = 0; i < t; ++i) {
            System.out.println(map.get(sarr[i]));
        }
    }
}

如果用Scanner会超时,Scanner对输入数据进行正则解析,但是BufferedReader只是简单地读取字符序列。所以会过

BufferedReader比Scanner要快

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2024年03月29日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   19天前   43   0   0 java
  TEZNKK3IfmPf   2024年05月31日   54   0   0 java
TEZNKK3IfmPf