60013 로봇 Platinum III

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

문제

수직선 위 서로 다른 위치에 NN개의 점프대가 설치되어 있다. ii번 점프대는 고정된 위치 XiX_i와 초기 점프 파워 PiP_i를 가진다. 당신은 이 수직선 위의 어떤 위치에 로봇을 놓을 것이다.

로봇은 다음과 같은 규칙에 따라 움직인다:

  • 로봇이 위치한 지점에 점프대가 없을 경우, 로봇은 왼쪽으로 11만큼 이동한다. 이 과정에서 11의 시간이 소요된다.
  • 로봇이 위치한 지점에 점프대가 있을 경우, 로봇은 즉시 점프대를 작동시켜 오른쪽으로 점프대의 파워만큼 이동한다. 점프 후 점프대의 파워는 기존의 두 배로 증가한다. 이 과정에서 11의 시간이 소요된다.

예를 들어, N=2N = 2개의 점프대가 다음과 같이 설치되어 있다고 하자.

점프대 번호위치 XiX_i초기 파워 PiP_i
112222
225533

로봇이 초기 위치 S=3S = 3에서 출발하여 T=7T = 7만큼의 시간 동안 이동하는 과정은 다음과 같다.

시간 (TT)로봇 위치설명점프대 상태
0033초기 위치에서 시작한다.P1=2P_1 = 2, P2=3P_2 = 3
1122점프대가 없으므로 왼쪽으로 11칸 이동했다.P1=2P_1 = 2, P2=3P_2 = 3
2244위치 22에 있는 11번 점프대를 작동시켜 오른쪽으로 22만큼 점프했다.P1=4P_1 = 4, P2=3P_2 = 3
3333점프대가 없으므로 왼쪽으로 11칸 이동했다.P1=4P_1 = 4, P2=3P_2 = 3
4422점프대가 없으므로 왼쪽으로 11칸 이동했다.P1=4P_1 = 4, P2=3P_2 = 3
5566위치 22에 있는 11번 점프대를 작동시켜 오른쪽으로 44만큼 점프했다.P1=8P_1 = 8, P2=3P_2 = 3
6655점프대가 없으므로 왼쪽으로 11칸 이동했다.P1=8P_1 = 8, P2=3P_2 = 3
7788위치 55에 있는 22번 점프대를 작동시켜 오른쪽으로 33만큼 점프했다.P1=8P_1 = 8, P2=6P_2 = 6

QQ개의 정수 쌍 (Sj,Tj)(S_j , T_j ) (1jQ1 ≤ j ≤ Q)이 주어진다. 각 쌍에 대해, 로봇이 위치 SjS_j에서 출발하여 정확히 TjT_j의 시간이 지난 후 도달하게 되는 위치를 구하는 프로그램을 작성하라.

로봇의 위치는 서로 독립적으로 계산되어야 하며, 항상 점프대의 초기 상태에서 시작한다. 즉, 각 경우마다 로봇은 수직선 위에 단 하나 존재하며, 점프대의 파워는 입력에서 주어진 초깃값으로부터 다시 시작한다.

입력

첫 번째 줄에 NN이 주어진다.

다음 NN개의 줄에 걸쳐 NN개의 정수 쌍이 주어진다. 이 중 ii (1iN1 ≤ i ≤ N)번째 줄에는 XiX_iPiP_i가 공백을 사이에 두고 주어진다.

다음 줄에는 QQ가 주어진다.

다음 QQ개의 줄에 걸쳐 QQ개의 정수 쌍이 주어진다. 이 중 jj (1jQ1 ≤ j ≤ Q)번째 줄에는 SjS_jTjT_j가 공백을 사이에 두고 주어진다.

출력

QQ개의 줄을 출력한다. 이 중 jj (1jQ1 ≤ j ≤ Q)번째 줄에는 로봇이 SjS_j에서 출발하여 정확히 TjT_j의 시간이 지난 후 도달하는 위치를 출력한다.

제한

  • 주어지는 모든 수는 정수이다.
  • 1N3000001 ≤ N ≤ 300\, 000
  • 1017X1<X2<<XN1017−10^{17} ≤ X_1 < X_2 < \dots < X_N ≤ 10^{17}
  • 1Pi10171 ≤ P_i ≤ 10^{17} (1iN1 ≤ i ≤ N)
  • 1Q3000001 ≤ Q ≤ 300\, 000
  • 1017Sj1017−10^{17} ≤ S_j ≤ 10^{17}, 1Tj10171 ≤ T_j ≤ 10^{17} (1jQ1 ≤ j ≤ Q)

서브태스크

번호배점제한
15N=1N = 1
211N=2N = 2
36N,Q300N, Q ≤ 300, 1iN1 ≤ i ≤ N인 모든 ii에 대하여 $
47N,Q3000N, Q ≤ 3\, 000, 1iN1 ≤ i ≤ N인 모든 ii에 대하여 $
512N,Q9000N, Q ≤ 9\, 000
623N9000N ≤ 9\, 000
736추가 제약 조건 없음.

예제 입출력

예제 입력 1
2
2 2
5 3
7
3 1
3 2
3 3
3 4
3 5
3 6
3 7
예제 출력 1
2
4
3
2
6
5
8
예제 입력 2
3
-3 3
2 2
11 6
4
1 6
6 12
11 3
9 4
예제 출력 2
-1
2
15
5

출처

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