| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 1 초 (추가 시간 없음) | 1024 MB (추가 메모리 없음) | 374 | 190 | 172 | 53.918% |
크기가 무한한 정사각 격자가 있다. 이 격자 위에 $N$개의 1ドル \times 1$ 정사각형들을 각각 서로 다른 칸에 배치하려고 한다.
다음 조건들을 만족하는 도형 중 둘레가 최소인 도형을 최소 경계 직사각형이라고 하자.
$N$개의 정사각형을 배치하는 방법들 중 최소 경계 직사각형의 둘레가 가장 짧은 경우는 어떤 경우일까?
첫 번째 줄에 테스트 케이스의 개수 $T$가 주어진다. (1ドル \le T \le 2 \times 10^5$)
두 번째 줄부터 $T$개의 줄에 걸쳐 각 줄에 하나씩, 배치하고자 하는 정사각형의 개수 $N$이 주어진다. (1ドル \le N \le 10^9$)
각 테스트 케이스마다 최소 경계 직사각형의 둘레가 가장 짧은 경우의 둘레를 출력한다.
3 9 14 33
12 16 24
아래의 그림은 예제의 테스트 케이스를 나타낸다.
이 문제는 입력 데이터의 용량이 커서, 시간 초과를 받지 않으려면 빠른 입출력 방법을 사용해야 할 수 있다.
cin/cout을 사용하고자 한다면:
cin.tie(nullptr)와 ios::sync_with_stdio(false)를 main 함수 안의 맨 위에 적는다.endl 대신 개행 문자(\n)를 사용한다.scanf/printf/puts/getchar/putchar 등 C의 입출력 방식을 사용하면 안 된다.Scanner와 System.out.println 대신 BufferedReader와 BufferedWriter를 사용한다.BufferedWriter.flush를 마지막에 한 번 수행한다.input 대신 sys.stdin.readline을 사용한다. 단, 이 함수는 맨 끝의 개행 문자까지 같이 입력받음에 유의한다..rstrip()을 추가로 해 주는 것이 좋다.