본문 바로가기
알고리즘/백준

[백준 15552번 ː 자바(JAVA)] 빠른 A+B

by 그릿er 2020. 4. 19.

 

<문제>

 

본격적으로 for문 문제를 풀기 전에 주의해야 할 점이 있다. 입출력 방식이 느리면 여러 줄을 입력받거나 출력할 때 시간초과가 날 수 있다는 점이다.

C++을 사용하고 있고 cin/cout을 사용하고자 한다면, cin.tie(NULL)과 sync_with_stdio(false)를 둘 다 적용해 주고, endl 대신 개행문자(\n)를 쓰자. 단, 이렇게 하면 더 이상 scanf/printf/puts/getchar/putchar 등 C의 입출력 방식을 사용하면 안 된다.

Java를 사용하고 있다면, Scanner와 System.out.println 대신 BufferedReader와 BufferedWriter를 사용할 수 있다. BufferedWriter.flush는 맨 마지막에 한 번만 하면 된다.

Python을 사용하고 있다면, input 대신 sys.stdin.readline을 사용할 수 있다. 단, 이때는 맨 끝의 개행문자까지 같이 입력받기 때문에 문자열을 저장하고 싶을 경우 .rstrip()을 추가로 해 주는 것이 좋다.

또한 입력과 출력 스트림은 별개이므로, 테스트케이스를 전부 입력받아서 저장한 뒤 전부 출력할 필요는 없다. 테스트케이스를 하나 받은 뒤 하나 출력해도 된다.

 

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
import java.io.*;
import java.util.*;
 
 
public class Main {
 
    public static void main(String[] args) throws IOException {
        
       BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
       BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
       
       int n = Integer.parseInt(br.readLine());
       for(int i=0; i<n; i++) {
           StringTokenizer st = new StringTokenizer(br.readLine());
           int num1 = Integer.parseInt(st.nextToken());
           int num2 = Integer.parseInt(st.nextToken());
           
           bw.write((num1+num2)+"\n");
          }
       bw.flush();
       
        } 
        
    }
 
 
 
 

 

 

 


 

 

Scanner 를 쓰거나 System.out.print 를 쓰면 시간이 초과된다.

 

Scanner는 사용하기 편리하지만 속도가 느리기 때문에 빠른 속도를 내야하는 이 문제에는 적합하지 않다. 

 

따라서, BufferedReader 와 BufferedWriter 를 사용해서 입출력을 해주었고,

 

StringTokenizer 도 같이 사용해주었다.

 

 

-StringTokenizer() : 아무 값도 가지지 않는 부분이 나오면 무시하고 지나가서 깔끔하게 문자열이 분리가 가능하다.