Please subscribe to the official Codeforces channel in Telegram via the link: https://t.me/codeforces_official.
×

No tag edit access

C. Fetch the Treasure

time limit per test

3 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputRainbow built *h* cells in a row that are numbered from 1 to *h* from left to right. There are *n* cells with treasure. We call each of these *n* cells "Treasure Cell". The *i*-th "Treasure Cell" is the *a*_{i}-th cell and the value of treasure in it is *c*_{i} dollars.

Then, Freda went in the first cell. For now, she can go just *k* cells forward, or return to the first cell. That means Freda was able to reach the 1st, (*k* + 1)-th, (2·*k* + 1)-th, (3·*k* + 1)-th cells and so on.

Then Rainbow gave Freda *m* operations. Each operation is one of the following three types:

- Add another method
*x*: she can also go just*x*cells forward at any moment. For example, initially she has only one method*k*. If at some moment she has methods*a*_{1},*a*_{2}, ...,*a*_{r}then she can reach all the cells with number in form , where*v*_{i}— some non-negative integer. - Reduce the value of the treasure in the
*x*-th "Treasure Cell" by*y*dollars. In other words, to apply assignment*c*_{x}=*c*_{x}-*y*. - Ask the value of the most valuable treasure among the cells Freda can reach. If Freda cannot reach any cell with the treasure then consider the value of the most valuable treasure equal to 0, and do nothing. Otherwise take the most valuable treasure away. If several "Treasure Cells" have the most valuable treasure, take the "Treasure Cell" with the minimum number (not necessarily with the minimum number of cell). After that the total number of cells with a treasure is decreased by one.

As a programmer, you are asked by Freda to write a program to answer each query.

Input

The first line of the input contains four integers: *h* (1 ≤ *h* ≤ 10^{18}), *n*, *m* (1 ≤ *n*, *m* ≤ 10^{5}) and *k* (1 ≤ *k* ≤ 10^{4}).

Each of the next *n* lines contains two integers: *a*_{i} (1 ≤ *a*_{i} ≤ *h*), *c*_{i} (1 ≤ *c*_{i} ≤ 10^{9}). That means the *i*-th "Treasure Cell" is the *a*_{i}-th cell and cost of the treasure in that cell is *c*_{i} dollars. All the *a*_{i} are distinct.

Each of the next *m* lines is in one of the three following formats:

- "1
*x*" — an operation of type 1, 1 ≤*x*≤*h*; - "2
*x**y*" — an operation of type 2, 1 ≤*x*≤*n*, 0 ≤*y*<*c*_{x}; - "3" — an operation of type 3.

There are at most 20 operations of type 1. It's guaranteed that at any moment treasure in each cell has positive value. It's guaranteed that all operations is correct (no operation can decrease the value of the taken tresure).

Please, do not use the %lld specifier to read 64-bit integers in С++. It is preferred to use the cin, cout streams or the %I64d specifier.

Output

For each operation of type 3, output an integer indicates the value (in dollars) of the most valuable treasure among the "Treasure Cells" Freda can reach. If there is no such treasure, output 0.

Examples

Input

10 3 5 2

5 50

7 60

8 100

2 2 5

3

1 3

3

3

Output

55

100

50

Note

In the sample, there are 10 cells and 3 "Treasure Cells". The first "Treasure Cell" is cell 5, having 50 dollars tresure in it. The second "Treasure Cell" is cell 7, having 60 dollars tresure in it. The third "Treasure Cell" is cell 8, having 100 dollars tresure in it.

At first, Freda can only reach cell 1, 3, 5, 7 and 9. In the first operation, we reduce the value in the second "Treasure Cell" from 60 to 55. Then the most valuable treasure among the "Treasure Cells" she can reach is max(50, 55) = 55. After the third operation, she can also go 3 cells forward each step, being able to reach cell 1, 3, 4, 5, 6, 7, 8, 9, 10. So the most valuable tresure is 100.

Noticed that she took the 55 dollars and 100 dollars treasure away, so the last answer is 50.

Codeforces (c) Copyright 2010-2018 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Dec/13/2018 12:53:43 (d3).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|