Scanner与System.out为什么慢,快速输入输出模版,目录牛客.dd爱框框快速输入的代码快速输入输出快的原因 AC代码

简介: Scanner与System.out为什么慢,快速输入输出模版,目录牛客.dd爱框框快速输入的代码快速输入输出快的原因 AC代码

JAVA处理IO有两套标准

1.字节流

2.字符流

牛客.dd爱框框

快速输入的代码

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
 
public class Read {
    //字符串裁剪
    StringTokenizer st=new StringTokenizer("");
    //1.把字节流转化为字符流
    从IO设备中拿数据,先是建立一个内存缓冲区,然后以后都从他的内存缓冲区拿数据,
    BufferedReader bf=new BufferedReader(new InputStreamReader(System.in));
    // 再从从内存缓冲区里面拿数据
    String next()throws IOException{
        //看他后面还有没有要裁切的数据
        while(!st.hasMoreTokens()){
            //bf.nextLine:直接在内存缓存区里面,拿一行数据,交给这个字符串裁切对象
            st=new StringTokenizer(bf.readLine());
        }
        //再返回新读入这一行
        return  st.nextToken();
    }
 
    String nextLine() throws IOException
    {
        return bf.readLine();
    }
 
    int nextInt() throws IOException
    {
        return Integer.parseInt(next());
    }
 
    long nextLong() throws IOException
    {
        return Long.parseLong(next());
    }
 
    double nextDouble() throws IOException
    {
        return Double.parseDouble(next());
    }
}

快速输入输出快的原因

我开始真的是不清楚,这种输入输出有啥用,也没有人给我讲讲,它的原理是什么

直到,有些事情,自己经历过就清楚什么用,我就再想我的代码有啥问题,自己检查半天也不清楚啥问题,以为有奇怪的吊炸天的例子,直到我看到题解里面快速输出。我去尝试,发现确实是这样

Scanner与System.out,这两个都是他们区访问IO设备,每次输入输出都会访问IO设备

那么BufferedReader起到作用的是什么呢

next()的意思

如何快速读入呢(在这里,使用的是)

public static PrintWriter out = new PrintWriter(new BufferedWriter(new OutputStreamWriter(System.out)));

这里其实bufferedWriter,就已经足够,但是使用这个PrintWriter,我们可以像是之前一样,使用println之类的,换句话学习成本低。

AC代码

import java.util.*;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
 
public class Main{
    public static void main(String[]args) throws IOException{
        Read scanner=new Read();
        int a1=scanner.nextInt();
        int b1=scanner.nextInt();
        int []a=new int[a1];
        for(int i=0;i<a1;i++){
            a[i]=scanner.nextInt();
        }
        int left=0;
        int right=0;
        int count=0;
        int []sum=new int[2];
        sum[0]=Integer.MAX_VALUE;
        sum[1]=Integer.MAX_VALUE;
        int ret=Integer.MAX_VALUE;
        while(right<a1&&left<=right) {
            if (count < b1)
                count += a[right];
                while (count >= b1&&left<=right) {
                    if (right - left + 1 <= ret && count >= b1) {
                        if (right - left + 1 == ret) {
                            sum[0] = Math.min(left + 1, sum[0]);
                            sum[1] = Math.min(right + 1, sum[1]);
                        } else {
                            sum[0] = left + 1;
                            sum[1] = right + 1;
                            ret = Math.min(right - left + 1, ret);
                        }
                    }
                    count -= a[left];
                    left++;
                }
            right++;
            }
 
        System.out.print(sum[0]+" "+sum[1]);
    }
    
}
class Read {
    //字符串裁剪
    StringTokenizer st=new StringTokenizer("");
    //1.把字节流转化为字符流
    从IO设备中拿数据,先是建立一个内存缓冲区,然后以后都从他的内存缓冲区拿数据,
    BufferedReader bf=new BufferedReader(new InputStreamReader(System.in));
    // 再从从内存缓冲区里面拿数据
    String next()throws IOException{
        //看他后面还有没有要裁切的数据
        while(!st.hasMoreTokens()){
            //bf.nextLine:直接在内存缓存区里面,拿一行数据,交给这个字符串裁切对象
            st=new StringTokenizer(bf.readLine());
        }
        //再返回新读入这一行
        return  st.nextToken();
    }
 
    String nextLine() throws IOException
    {
        return bf.readLine();
    }
 
    int nextInt() throws IOException
    {
        return Integer.parseInt(next());
    }
 
    long nextLong() throws IOException
    {
        return Long.parseLong(next());
    }
 
    double nextDouble() throws IOException
    {
        return Double.parseDouble(next());
    }
}


相关文章
|
SQL 数据挖掘 数据库
HiveSQL分位数函数percentile()使用详解+实例代码
HiveSQL分位数函数percentile()使用详解+实例代码
5101 0
HiveSQL分位数函数percentile()使用详解+实例代码
|
5月前
|
人工智能 Java 容器
十个Java字符串操作示例程序
十个Java字符串操作示例程序
42 1
|
Java 程序员 开发工具
程序员入门的第一个程序,打印输出 “ HelloWorld “
程序员入门的第一个程序,使用 Java 打印输出 " HelloWorld "
201 0
程序员入门的第一个程序,打印输出 “ HelloWorld “
廖雪峰课后作业-利用os模块编写一个能实现dir -l输出的程序
廖雪峰课后作业-利用os模块编写一个能实现dir -l输出的程序
116 0
廖雪峰课后作业-利用os模块编写一个能实现dir -l输出的程序
|
前端开发 开发者
评论列表案例-演示艾特符号替代相对路径的好处|学习笔记
快速学习评论列表案例-演示艾特符号替代相对路径的好处
461 0
|
Unix
C代码中__LINE__输出时与代码行号不同的解决办法
C代码中__LINE__输出时与代码行号不同的解决办法
94 0
输入一个整形数(最多可以到亿位),然后按汉语的习惯,将其读出来并输出。如1052,读作:一千零五十二。 程序运行示例: 1052 一千零五十二
输入一个整形数(最多可以到亿位),然后按汉语的习惯,将其读出来并输出。如1052,读作:一千零五十二。 程序运行示例: 1052 一千零五十二
193 0
|
缓存 Shell 开发工具
Shell脚本编程实践——第4关:编写一个脚本,计算txt文件中每一行单词的个数并将结果写入另一个文件
Shell脚本编程实践——第4关:编写一个脚本,计算txt文件中每一行单词的个数并将结果写入另一个文件
1013 0
|
XML 存储 JSON
无事来学学--Kettle中输入,输出组件的使用(一)
CSV文件 一种带有固定格式的文本文件。注意:获取字段的时候可以调整自己的字段类型,格式,满足自己的需求哦。
254 0
|
SQL 数据库
无事来学学--Kettle中输入,输出组件的使用(三)
CSV文件 一种带有固定格式的文本文件。注意:获取字段的时候可以调整自己的字段类型,格式,满足自己的需求哦。
170 0