60014 상자 보관 Platinum IV

시간 제한: 2초 메모리 제한: 2048MB

문제

정올이는 창고에 상자를 보관하려고 한다. 상자는 총 NN개가 있으며 11부터 NN까지의 번호가 붙어 있다. ii (1iN1 ≤ i ≤ N)번 상자의 크기sis_i, 보관 용량cic_i이다. 모든 상자는 보관 용량이 그 크기보다 작다. 즉, ci<sic_i < s_i를 만족한다.

창고에 상자가 너무 많아 복잡하다고 생각한 정올이는, 상자를 다른 상자의 안에 넣어서 보관하고자 한다. 이때, 다음과 같은 조건이 만족되어야 한다.

  • 한 상자에는 해당 상자의 보관 용량 이하의 크기를 갖는 상자를 넣을 수 있다.
  • 이미 상자를 포함한 상자를 다른 상자 안에 넣는 것도 가능하다.
  • 한 상자에 직접 포함되는 상자는 최대 하나여야 한다. 다시 말해, 한 상자 안에는 다른 상자를 최대 하나 넣을 수 있지만, 그 다른 상자 안에 또 다른 상자들이 들어가 있는 것은 허용된다.

상자를 보관하는 비용은 다른 상자에 포함되지 않은 상자의 개수와 같다.

예를 들어, N=4N = 4이고, 네 상자의 크기와 보관 용량이 각각 아래 표와 같은 경우를 생각하자.

번호크기보관 용량
116644
225511
339988
442211

이때, 아래 그림처럼 44번 상자를 11번 상자에 넣고, 11번 상자를 33번 상자에 넣으면, 다른 상자에 포함되지 않은 상자의 수는 22개가 되고, 따라서 상자를 보관하는 비용은 22가 된다.

그러나 아래 그림처럼 22번 상자와 44번 상자를 33번 상자에 넣는 경우, 33번 상자 안에 두 개의 상자가 직접 포함되어 있으므로, 조건을 만족하지 않는다.

창고에 반드시 모든 상자를 둘 필요는 없어서, 정올이는 번호가 작은 몇 개의 상자만 보관하고 나머지 상자는 버릴 계획을 하고 있다. 정올이는 아직 몇 개의 상자를 사용할지는 정하지 못한 상태이다.

정올이를 도와, 11부터 NN까지의 모든 ii에 대해, 1,2,,i1, 2, \dots ,i번 상자를 보관하는 데 드는 최소 비용을 계산하는 프로그램을 작성하라.

입력

첫 번째 줄에는 상자의 수 NN이 주어진다.

두 번째 줄부터 NN개의 줄에 걸쳐 각 상자의 정보가 주어진다. 이 중 ii번째 줄에는 ii번 상자의 크기 sis_i와 보관 용량 cic_i가 공백을 사이에 두고 주어진다.

출력

NN개의 줄을 출력한다.

ii (1iN1 ≤ i ≤ N)번째 줄에는 1,2,,i1, 2,\dots ,i번 상자를 보관하는 데 드는 최소 비용을 출력한다.

제한

  • 주어지는 모든 수는 정수이다.
  • 2N2×1052 ≤ N ≤ 2 \times 10^5
  • 1ci<si1091 ≤ c_i < s_i ≤ 10^9 (1iN1 ≤ i ≤ N)

서브태스크

번호배점제한
17N6N ≤ 6.
212si=ci+1s_i = c_i + 1.
326N1000N ≤ 1000.
417si100s_i ≤ 100.
538추가 제약 조건 없음.

예제 입출력

예제 입력 1
4
6 4
5 1
9 8
2 1
예제 출력 1
1
2
2
2
예제 입력 2
6
3 2
5 4
3 2
4 3
4 3
3 2
예제 출력 2
1
1
2
2
2
3
예제 입력 3
8
13 6
7 5
9 4
11 10
4 2
15 5
16 7
8 3
예제 출력 3
1
2
3
3
3
4
4
5

출처

올림피아드 한국정보올림피아드 KOI 2025 2차 초등부 4번
solution.cpp
에디터 불러오는 중...