atcoder#AGC023D. [AGC023D] Go Home

[AGC023D] Go Home

Score : 12001200 points

Problem Statement

There are NN apartments along a number line, numbered 11 through NN. Apartment ii is located at coordinate XiX_i. Also, the office of AtCoder Inc. is located at coordinate SS. Every employee of AtCoder lives in one of the NN apartments. There are PiP_i employees who are living in Apartment ii.

All employees of AtCoder are now leaving the office all together. Since they are tired from work, they would like to get home by the company's bus. AtCoder owns only one bus, but it can accommodate all the employees. This bus will leave coordinate SS with all the employees and move according to the following rule:

  • Everyone on the bus casts a vote on which direction the bus should proceed, positive or negative. (The bus is autonomous and has no driver.) Each person has one vote, and abstaining from voting is not allowed. Then, the bus moves a distance of 11 in the direction with the greater number of votes. If a tie occurs, the bus moves in the negative direction. If there is an apartment at the coordinate of the bus after the move, all the employees who live there get off.
  • Repeat the operation above as long as there is one or more employees on the bus.

For a specific example, see Sample Input 1.

The bus takes one seconds to travel a distance of 11. The time required to vote and get off the bus is ignorable.

Every employee will vote so that he himself/she herself can get off the bus at the earliest possible time. Strictly speaking, when a vote is taking place, each employee see which direction results in the earlier arrival at his/her apartment, assuming that all the employees follow the same strategy in the future. Based on this information, each employee makes the optimal choice, but if either direction results in the arrival at the same time, he/she casts a vote to the negative direction.

Find the time the bus will take from departure to arrival at the last employees' apartment. It can be proved that, given the positions of the apartments, the numbers of employees living in each apartment and the initial position of the bus, the future movement of the bus is uniquely determined, and the process will end in a finite time.

Constraints

  • 1N1051 \leq N \leq 10^5
  • 1S1091 \leq S \leq 10^9
  • 1X1<X2<...<XN1091 \leq X_1 < X_2 < ... < X_N \leq 10^9
  • XiSX_i \neq S ( 1iN1 \leq i \leq N )
  • 1Pi1091 \leq P_i \leq 10^9 ( 1iN1 \leq i \leq N )
  • All values in input are integers.

Input

Input is given from Standard Input in the following format:

NN SS

X1X_1 P1P_1

X2X_2 P2P_2

::

XNX_N PNP_N

Output

Print the number of seconds the bus will take from departure to arrival at the last employees' apartment.

3 2
1 3
3 4
4 2
4

Assume that the bus moves in the negative direction first. Then, the coordinate of the bus changes from 22 to 11, and the employees living in Apartment 11 get off. The movement of the bus after that is obvious: it just continues moving in the positive direction. Thus, if the bus moves in the negative direction first, the coordinate of the bus changes as 212342 \to 1 \to 2 \to 3 \to 4 from departure. The time it takes to get home for the employees living in Apartment 11, 22, 33 are 11, 33, 44 seconds, respectively.

Next, assume that the bus moves in the positive direction first. Then, the coordinate of the bus changes from 22 to 33, and the employees living in Apartment 22 get off. Afterwards, the bus starts heading to Apartment 11, because there are more employees living in Apartment 11 than in Apartment 33. Then, after arriving at Apartment 11, the bus heads to Apartment 33. Thus, if the bus moves in the positive direction first, the coordinate of the bus changes as 23212342 \to 3 \to 2 \to 1 \to 2 \to 3 \to 4 from departure. The time it takes to get home for the employees living in Apartment 11, 22, 33 are 33, 11, 66 seconds, respectively.

Therefore, in the beginning, the employees living in Apartment 11 or 33 will try to move the bus in the negative direction. On the other hand, the employees living in Apartment 22 will try to move the bus in the positive direction in the beginning. There are a total of 3+2=53 + 2 = 5 employees living in Apartment 11 and 33 combined, which is more than those living in Apartment 22, which is 44. Thus, the bus will move in the negative direction first, and the coordinate of the bus will change as 212342 \to 1 \to 2 \to 3 \to 4 from departure.

6 4
1 10
2 1000
3 100000
5 1000000
6 10000
7 100
21

Since the numbers of employees living in different apartments are literally off by a digit, the bus consistently head to the apartment where the most number of employees on the bus lives.

15 409904902
94198000 15017
117995501 7656764
275583856 313263626
284496300 356635175
324233841 607
360631781 148
472103717 5224
497641071 34695
522945827 816241
554305668 32
623788284 22832
667409501 124410641
876731548 12078
904557302 291749534
918215789 5
2397671583