第一次笔试的时候不太熟悉Java的输入输出,会写的题目也没有AC。复盘的时候打算把Java的输入输出搞清楚。
一般笔试题输入,会分成一下几种情况:
下面的情况都是以Int
举例,其他数据类型换成相应的读入方法即可。
前两种情况是输入输出量很小的情况,用Scanner
一般不会超时,如果输入输出量很大的情况,Scanner
就会超时,这个时候用BufferedReader
和BufferedWriter
比较好。
先来看最简单的单行输入
主要是通过nextInt()
不停地读入
8 7 8 3 4 2 4 5 0
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
while(in.hasNext()) { // 牛客网推荐写法
int n = in.nextInt(); // 数组总数
int[] nums = new int[n]; // 创建数组
for(int i = 0; i < n; i++) {
nums[i] = in.nextInt(); // 读入数组元素
}
}
in.close();
}
}
这种情况也比较简单
以字节这次笔试的题目为例来讲
题目:
也是通过 nextInt()
import java.util.Scanner;
public class ChooseSeat {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
while(in.hasNext()) {
int n = in.nextInt(); // 读第一行的参数
int[] nums = new int[n]; // 创建数组
for(int i = 0; i < n; i++) {
nums[i] = in.nextInt(); // 不停的读入元素
}
}
in.close();
}
}
笔试的时候不知道这种情况怎么写,然后题没有写出来。
这种情况要next()
和 nextLint()
一起用。
还是以字节的笔试题为例。
题目:
比如说
4 2 // 共有4个病毒,2次分裂
2 2 3 // 共有2个致命的病毒,编号为2号和3号
0 1 2 // 0号病毒分裂为1号和2号病毒
1 3 // 1号病毒分裂为1号和3号病毒
前面两行比较好写,就是多行输入且每行参数个数确定
后R行,每行参数个数在这里插入代码片
不确定,需要用到nextLine()
,把这一行的所有数据都读进来,因为nextLine()
读入的类型是String,还要通过分割String来去掉行内的空格“ ”,具体代码如下:
import java.util.Scanner;
import java.util.List;
import java.util.ArrayList;
public class LowestCommonAncestor {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
while(in.hasNext()) {
int n = in.nextInt(); // 病毒总数
int r = in.nextInt(); // 分裂次数
int count = in.nextInt(); // 致命病毒数
int[] deathVirIndex = new int[count]; // 创建数组
for(int i = 0; i < count; i++) {
deathVirIndex[i] = in.nextInt(); // 读数组元素
}
List<List<Integer>> index = new ArrayList<>();
in.nextLine(); // 关键 要换行了
while(in.hasNextLine()) { // 一行一行读
String str = in.nextLine(); // 读取一行只能是字符串
String[] strIn = str.trim().split(" "); // 以空格分割
List<Integer> temp = new ArrayList<>();
for(int j = 0; j < strIn.length; j++) {
temp.add(Integer.parseInt(strIn[j]));
}
index.add(new ArrayList<>(temp));
}
}
in.close();
}
}
输入:
4 2
2 2 3
0 1 2
1 3
得到的后R行List:[[0,1,2],[1,3]]
这里的关键点在于 in.nextLine();
,读前面两行,用的是next(),读完后光标停在第二行末尾,需要换行才能到达第三行。
BufferedReader
和BufferedWriter
可以加快读写效率。
BufferedReader
类构造方法:
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
主要方法
int read(); //读取单个字符
int read(char[] cbuf, int off, int len); //将字符读到数组的一部分,返回读取的字符数
String readLine(); //读取一行
void close(); // 关闭流
BufferedWriter
类构造方法
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(System.out));
主要方法
void write(char ch); //写单个字符
void write(char []cbuf,int off,int len) //写字符数据的某一部分
void write(String s,int off,int len) //写字符串的某一部分
void newLine() //写一个行分隔符。
输入:
1 // T组数据,每组4行
5 // n张桌子
01102 // 每张桌子人数
6 // m个排队的人
MFMMFF // 排队人的性别
输出:每个人选几号桌
2
1
1
3
4
4
import java.util.*;
import java.io.*;
public class Main{
public static void main(String[] args) throws IOException{
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(System.out));
int total = Integer.parseInt(reader.readLine()); // 组数T
for(int i = 0; i < total; i++) {
int n = Integer.parseInt(reader.readLine()); // 桌子数 n
String strCount = reader.readLine(); // 每张桌子人数
int[] count = new int[n];
for(int j = 0; j < n; j++) {
count[j] = Integer.parseInt(strCount.substring(j, j + 1));
}
int m = Integer.parseInt(reader.readLine()); // 人数 m
String sex = reader.readLine(); // 排队人的性别
int[] index = getIndex(n, count, m, sex);
for(int in : index) {
writer.write(Integer.toString(in)); // 输出数组的元素
writer.newLine(); // 换行
}
}
writer.flush();
}
}