본격적으로 for문 문제를 풀기 전에 주의해야 할 점이 있다. 입출력 방식이 느리면 여러 줄을 입력받거나 출력할 때 시간초과가 날 수 있다는 점이다.
Java를 사용하고 있다면, Scanner
와 System.out.println
대신 BufferedReader
와 BufferedWriter
를 사용할 수 있다. BufferedWriter.flush
는 맨 마지막에 한 번만 하면 된다.
첫 줄에 테스트케이스의 개수 T가 주어진다. T는 최대 1,000,000이다. 다음 T줄에는 각각 두 정수 A와 B가 주어진다. A와 B는 1 이상, 1,000 이하이다.
package baekjoon;
import java.io.*;
import java.io.BufferedWriter;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.StringTokenizer;
public class Fplus {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
//반환되는 타입이 String이기 때문에, int형으로 형변환 해준다.
int T = Integer.parseInt(br.readLine());
//문자열 분리를 위해 매 반복마다 StringTokenizer 생성과 동시에 문자를 입력 받는다.
StringTokenizer st;
for(int i=0; i<T; i++) {
//br.readLine을 통해 입력 받아 StringTokenizer 함수를 통해 " "로 나누어 준것을 st에 저장
st = new StringTokenizer(br.readLine()," ");
//반환타입이 String이기 때문에 , int형으로 변환하여 저장
int A = Integer.parseInt(st.nextToken());
int B = Integer.parseInt(st.nextToken());
//bw를 통해 출력, 개행문자열인 \n을 더해주면 A+B는 자동으로 String으로 바뀐다.
bw.write(A+B + "\n");
}
//필수적으로 버퍼를 비운 뒤(flush)
bw.flush();
//닫아 주어야 한다.
bw.close();
br.close();
}
}
#### ```