개발후라이
개발후라이
개발후라이
  • 분류 전체보기 (287)
    • Web Front End (76)
      • Javascript & Typescript (26)
      • React (12)
      • Vue (4)
      • Nodejs (1)
      • HTML (6)
      • CSS (8)
      • HTTP (6)
      • 책 - Review (8)
    • TIL (0)
    • Problem Solved (135)
      • 알고리즘 (4)
      • BOJ (67)
      • Programmers (8)
      • HackerRank (33)
      • LeetCode (23)
    • 회고 (4)
      • 오늘의 회고 (16)
      • 주간 회고 (15)
      • 월간 회고 (7)
      • WakaTime (9)
    • Git (3)
    • 기타 (15)
      • 취업 (5)
      • 자격증 (1)

블로그 메뉴

  • GitHub
  • LinkedIn
  • 홈

인기 글

태그

  • 릿코드
  • JavaScript
  • 오늘의회고
  • 프론트엔드
  • 회고
  • TypeScript
  • 자바스크립트
  • 노개북
  • 개발자
  • 노마드북클럽

최근 댓글

최근 글

전체 방문자
오늘
어제

티스토리

hELLO · Designed By 정상우.
개발후라이

개발후라이

[BOJ][Java] 15552번 - 빠른 A+B
Problem Solved/BOJ

[BOJ][Java] 15552번 - 빠른 A+B

2019. 10. 29. 22:26
반응형

 

https://www.acmicpc.net/problem/15552

문제

본격적으로 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()을 추가로 해 주는 것이 좋다.

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

자세한 설명 및 다른 언어의 경우는 이 글에 설명되어 있다. --> [java] BufferedWriter 외에도, StringBuilder로 출력을 모아 놓았다가 그 String을 System.out.println하는 방법도 있습니다.

이 블로그 글에서 BOJ의 기타 여러 가지 팁을 볼 수 있다.

팁 중에 하나.. 그래 내가 오류지 채점이 오류겠어?

 

입력

첫 줄에 테스트케이스의 개수 T가 주어진다. T는 최대 1,000,000이다. 다음 T줄에는 각각 두 정수 A와 B가 주어진다. A와 B는 1 이상, 1,000 이하이다.

출력

각 테스트케이스마다 A+B를 한 줄에 하나씩 순서대로 출력한다.

예제 입력

5

1 1

12 34

5 500

40 60

1000 1000

예제 출력

2

46

505

100

2000

 

문제 풀이

버퍼를 사용하는게 스캐너보다 빠른지 지금 알았다.. 어쩐지 많이 쓰더라,,

Buffer 사용하여 입출력 받는 방법들을 간단하게 정리했다.

추가적인 Method는 여기(https://coding-factory.tistory.com/251)에 잘 설명되어 있다.

답 (Java)

 

근데 이렇게 버퍼 썼는데도 소요시간 무엇 ㄷㄷ 스캐너로는 꿈도 못꾸겠네.. 스캐너 안녕..

반응형
    'Problem Solved/BOJ' 카테고리의 다른 글
    • [BOJ][Java] 10951번 - A+B - 4
    • [BOJ][Java] 11022번 - A + B - 8
    • [BOJ][Java] 11021번 - A+B - 7
    • [BOJ][Java] 8393번 - 합
    개발후라이
    개발후라이
    어제보다 오늘 발전하기 위한 공간 https://github.com/choisohyun

    티스토리툴바