atcoder#AGC023D. [AGC023D] Go Home
[AGC023D] Go Home
Score : points
Problem Statement
There are apartments along a number line, numbered through . Apartment is located at coordinate . Also, the office of AtCoder Inc. is located at coordinate . Every employee of AtCoder lives in one of the apartments. There are employees who are living in Apartment .
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 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 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 . 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
- ( )
- ( )
- All values in input are integers.
Input
Input is given from Standard Input in the following format:
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 to , and the employees living in Apartment 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 from departure. The time it takes to get home for the employees living in Apartment , , are , , seconds, respectively.
Next, assume that the bus moves in the positive direction first. Then, the coordinate of the bus changes from to , and the employees living in Apartment get off. Afterwards, the bus starts heading to Apartment , because there are more employees living in Apartment than in Apartment . Then, after arriving at Apartment , the bus heads to Apartment . Thus, if the bus moves in the positive direction first, the coordinate of the bus changes as from departure. The time it takes to get home for the employees living in Apartment , , are , , seconds, respectively.
Therefore, in the beginning, the employees living in Apartment or will try to move the bus in the negative direction. On the other hand, the employees living in Apartment will try to move the bus in the positive direction in the beginning. There are a total of employees living in Apartment and combined, which is more than those living in Apartment , which is . Thus, the bus will move in the negative direction first, and the coordinate of the bus will change as 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