로봇
시간 제한: 2000ms메모리 제한: 2048MB출처: KOI 2025 2차BOJ 34206
문제
수직선 위 서로 다른 위치에 개의 점프대가 설치되어 있다. 번 점프대는 고정된 위치 와 초기 점프 파워 를 가진다. 당신은 이 수직선 위의 어떤 위치에 로봇을 놓을 것이다.
로봇은 다음과 같은 규칙에 따라 움직인다:
- 로봇이 위치한 지점에 점프대가 없을 경우, 로봇은 왼쪽으로 만큼 이동한다. 이 과정에서 의 시간이 소요된다.
- 로봇이 위치한 지점에 점프대가 있을 경우, 로봇은 즉시 점프대를 작동시켜 오른쪽으로 점프대의 파워만큼 이동한다. 점프 후 점프대의 파워는 기존의 두 배로 증가한다. 이 과정에서 의 시간이 소요된다.
예를 들어, 개의 점프대가 다음과 같이 설치되어 있다고 하자.
| 점프대 번호 | 위치 | 초기 파워 |
|---|---|---|
로봇이 초기 위치 에서 출발하여 만큼의 시간 동안 이동하는 과정은 다음과 같다.
| 시간 () | 로봇 위치 | 설명 | 점프대 상태 |
|---|---|---|---|
| 초기 위치에서 시작한다. | , | ||
| 점프대가 없으므로 왼쪽으로 칸 이동했다. | , | ||
| 위치 에 있는 번 점프대를 작동시켜 오른쪽으로 만큼 점프했다. | , | ||
| 점프대가 없으므로 왼쪽으로 칸 이동했다. | , | ||
| 점프대가 없으므로 왼쪽으로 칸 이동했다. | , | ||
| 위치 에 있는 번 점프대를 작동시켜 오른쪽으로 만큼 점프했다. | , | ||
| 점프대가 없으므로 왼쪽으로 칸 이동했다. | , | ||
| 위치 에 있는 번 점프대를 작동시켜 오른쪽으로 만큼 점프했다. | , |
개의 정수 쌍 (1 ≤ j ≤ Q)이 주어진다. 각 쌍에 대해, 로봇이 위치 에서 출발하여 정확히 의 시간이 지난 후 도달하게 되는 위치를 구하는 프로그램을 작성하라.
로봇의 위치는 서로 독립적으로 계산되어야 하며, 항상 점프대의 초기 상태에서 시작한다. 즉, 각 경우마다 로봇은 수직선 위에 단 하나 존재하며, 점프대의 파워는 입력에서 주어진 초깃값으로부터 다시 시작한다.
입력
첫 번째 줄에 이 주어진다.
다음 개의 줄에 걸쳐 개의 정수 쌍이 주어진다. 이 중 (1 ≤ i ≤ N)번째 줄에는 와 가 공백을 사이에 두고 주어진다.
다음 줄에는 가 주어진다.
다음 개의 줄에 걸쳐 개의 정수 쌍이 주어진다. 이 중 (1 ≤ j ≤ Q)번째 줄에는 와 가 공백을 사이에 두고 주어진다.
출력
개의 줄을 출력한다. 이 중 (1 ≤ j ≤ Q)번째 줄에는 로봇이 에서 출발하여 정확히 의 시간이 지난 후 도달하는 위치를 출력한다.
예제
예제 1
입력
2 2 2 5 3 7 3 1 3 2 3 3 3 4 3 5 3 6 3 7
출력
2 4 3 2 6 5 8
예제 2
입력
3 -3 3 2 2 11 6 4 1 6 6 12 11 3 9 4
출력
-1 2 15 5
코드를 제출하려면 로그인하세요.