算法学习 --> 快速输入和输出

快速输入/输出

Scanner 和 System.out java调用IO太慢了,

  1. Scanner 每次读都需要调用 物理的IO机器, 所以读一定会超时

  2. System.out 也一样, 每次读都需要调用IO

  3. java分为两种读写 : 1. 字节流 , 2. 字符流 而 Scanner 和 System.out 就是 字节流

// 首先导入包

import java.io.*;

import java.util.*;

public class IOTest {

// 快速写对象 // 套一层 PrintWriter,使用 out 就和 System.out里的方法一样

private static PrintWriter out = new PrintWriter(

new BufferedWriter( // 将输出 给输出到 缓冲区里,最后在close刷新缓冲区

new OutputStreamWriter(System.out))); // 将输出 转成字符流

// 创建快速读对象

private static Read in = new Read();

public static void main(String\[\] args) throws IOException {

// 最重要的 ,输出要刷新缓冲区

out.close() ;

}

}

// 快速读

class Read{

// Tokenizer 是裁剪的意思

// StringTokenizer 就是做字符串裁剪的意思

private StringTokenizer st = new StringTokenizer("") ;

// Buffered 就是缓冲

// inputStreamReader 就是将字节流转为字符流

// 让后通过 BufferedReader 把 所有的输入 全部一次性给读到 一个 缓冲区里

// 后面要 读取数据 , 就直接从缓冲区里拿

private BufferedReader bf = new BufferedReader(new InputStreamReader(System.in)) ;

// 按Scanner相同的名字来定义方法

String next() throws IOException{ // readLine需要抛异常

//需要一个while 循环, 当 stringTokenizer 字符串裁剪没有东西的时候,

// 从缓冲区里取出一行 ,来 方便我们进行读操作

while(!st.hasMoreTokens()){

st = new StringTokenizer(bf.readLine());

}

// 缓冲区里有多行数据 , bf.readLine里把一行数据拿出来,给 st 字符串裁剪

// st.nextToken() 就是从这 一行数据里 , 裁剪一个数据出来

return st.nextToken() ;

}

//获取一行字符串

String nextLine() throws IOException{

return bf.readLine() ; // 直接返回一行数据

}

// 下面的方法就换成各个类型数据

int newInt() throws IOException {

return Integer.parseInt(next()) ;

}

long newLong() throws IOException {

return Long.parseLong(next());

}

float newFloat() throws IOException{

return Float.parseFloat(next()) ;

}

}

相关推荐
JieE2128 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack2015 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树17 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
唐青枫21 小时前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马1 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261351 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261351 天前
Java 打印 Word 文档:从基础打印到高级设置
java
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法