시간 제한 메모리 제한 제출 정답 맞은 사람 정답 비율
2 초 512 MB 43 8 8 100.000%

문제

고대 공룡들이 남쪽에서 북쪽 방향으로 걸어간 발자국들이 발견되었다. 아래 그림은 발견된 공룡 발자국들의 다양한 예이다.

발자국을 분석한 결과 모든 발자국은 하나의 발뒤꿈치와 k개의 발가락 (k ≥ 2)을 가지며, 두 발가락 사이마다 골이 존재한다. 이를 바탕으로 위 그림의 발자국을 단순화시켜보면 아래와 같이 2k각형으로 표현이 된다.

발자국의 다각형에서 발뒤꿈치를 시작으로 반시계 방향으로 돌면 항상 첫 번째 발가락에서 좌회전, 첫 번째 골에서 우회전, 두 번째 발가락에서 좌회전, 두 번째 골에서 우회전, ……, k-1번째 골에서 우회전, k번째 발가락에서 좌회전해서 발뒤꿈치로 돌아오게 된다. 또한 발뒤꿈치와 발가락을 선분으로 잇는 경우 다음 조건을 항상 만족한다.

  1. 해당 선분은 발자국의 다각형을 벗어나지 않는다.
  2. 해당 선분은 골을 지나지 않는다.

다음 그림은 발자국이 될 수 없는 다각형들의 예이다.

조건 1 위배 조건 2 위배

발자국이 발견된 일부 지역에서는 불행히도 정확한 발자국이 남아있지 않고 발자국 다각형의 꼭짓점이 될 수 있는 점들만 남아있다. 심지어 여기에는 발자국과 관련 없는 점들도 같이 남아있을 수 있다. 각 점의 위치는 좌표 (x, y)로 표현되며, x값은 서쪽에서 동쪽으로 증가하고 y값은 남쪽에서 북쪽으로 증가한다. 다행히도 점들 중 가장 남쪽에 있는 점은 유일하며 발뒤꿈치가 된다. 다음 그림의 예에서 보면 (20, 5) 점(붉은 점)이 가장 남쪽에 위치하므로 발뒤꿈치이다.

주어진 점들로 만들 수 있는 가장 많은 발가락을 가진 발자국을 찾고 싶다. 아래는 위 그림에서 찾은 가장 많은 발가락을 가진 발자국의 한 예이다.

점들의 좌표를 입력으로 받아서, 가장 많은 발가락을 가진 발자국을 하나 찾은 뒤 찾은 다각형의 꼭짓점의 개수와 각 꼭짓점의 좌표를 출력하는 프로그램을 작성하라.

입력

표준 입력으로 다음 정보가 주어진다. 첫 번째 줄에는 점의 수를 나타내는 정수 N이 주어진다. 다음 N개의 각 줄에는 한 점의 x좌표와 y좌표를 나타내는 두 정수가 주어진다. 입력으로 주어진 점들은 모두 서로 다르다는 것이 보장되고, y좌표가 가장 작은 점이 유일하다는 것도 보장된다.

출력

표준 출력으로, 첫 번째 줄에는 가장 많은 발가락을 가진 발자국 다각형의 꼭짓점의 개수 T를 출력한다. 다음 T개의 각 줄에는 발뒤꿈치부터 시작하여 반시계 방향으로 돌면서 각 꼭짓점의 x좌표와 y좌표를 출력한다. 그러한 발자국이 여러 개가 있다면 그 중 하나의 발자국만 출력한다. 발자국이 존재할 수 없는 경우 0을 출력한다.

제한

모든 서브태스크에서 -108 ≤ x, y ≤ 108 이다.

서브태스크 1 (14점)

4 ≤ N ≤ 3,000, T = N이다.

서브태스크 2 (12점)

4 ≤ N ≤ 10이다.

서브태스크 3 (29점)

4 ≤ N ≤ 300이다.

서브태스크 4 (45점)

4 ≤ N ≤ 3,000이다.

예제 입력 1

6
3 0
5 10
4 9
3 10
2 9
1 10

예제 출력 1

6
3 0
5 10
4 9
3 10
2 9
1 10

예제 입력 2

6
1 20
2 18
4 17
3 10
5 5
0 0

예제 출력 2

6
0 0
5 5
3 10
4 17
2 18
1 20

예제 입력 3

13
20 12
27 20
10 18
16 24
8 10
24 25
20 5
18 20
16 19
30 10
11 6
31 21
16 13

예제 출력 3

8
20 5
31 21
27 20
24 25
18 20
16 24
16 13
10 18

출처

Olympiad > 한국정보올림피아드 > KOI 2018 > 중등부 4번

  • 문제의 오타를 찾은 사람: jh05013
  • 스페셜 저지를 만든 사람: jung2381187