Preparing NOJ

Alice received a set of Toy Train™ from Bob. It consists of one train and a connected railway network of $$$n$$$ stations, enumerated from $$$1$$$ through $$$n$$$. The train occupies one station at a time and travels around the network of stations in a circular manner. More precisely, the immediate station that the train will visit after station $$$i$$$ is station $$$i+1$$$ if $$$1 \leq i < n$$$ or station $$$1$$$ if $$$i = n$$$. It takes the train $$$1$$$ second to travel to its next station as described.

Bob gave Alice a fun task before he left: to deliver $$$m$$$ candies that are initially at some stations to their independent destinations using the train. The candies are enumerated from $$$1$$$ through $$$m$$$. Candy $$$i$$$ ($$$1 \leq i \leq m$$$), now at station $$$a_i$$$, should be delivered to station $$$b_i$$$ ($$$a_i \neq b_i$$$).

The train has infinite capacity, and it is possible to load off any number of candies at a station. However, only at most one candy can be loaded from a station onto the train before it leaves the station. You can choose any candy at this station. The time it takes to move the candies is negligible.

Now, Alice wonders how much time is needed for the train to deliver all candies. Your task is to find, for each station, the minimum time the train would need to deliver all the candies were it to start from there.

The first line contains two space-separated integers $$$n$$$ and $$$m$$$ ($$$2 \leq n \leq 5\,000$$$; $$$1 \leq m \leq 20\,000$$$) — the number of stations and the number of candies, respectively.

The $$$i$$$-th of the following $$$m$$$ lines contains two space-separated integers $$$a_i$$$ and $$$b_i$$$ ($$$1 \leq a_i, b_i \leq n$$$; $$$a_i \neq b_i$$$) — the station that initially contains candy $$$i$$$ and the destination station of the candy, respectively.

In the first and only line, print $$$n$$$ space-separated integers, the $$$i$$$-th of which is the minimum time, in seconds, the train would need to deliver all the candies were it to start from station $$$i$$$.

5 7 2 4 5 1 2 3 3 4 4 1 5 3 3 5

10 9 10 10 9

2 3 1 2 1 2 1 2

5 6

Consider the second sample.

If the train started at station $$$1$$$, the optimal strategy is as follows.

- Load the first candy onto the train.
- Proceed to station $$$2$$$. This step takes $$$1$$$ second.
- Deliver the first candy.
- Proceed to station $$$1$$$. This step takes $$$1$$$ second.
- Load the second candy onto the train.
- Proceed to station $$$2$$$. This step takes $$$1$$$ second.
- Deliver the second candy.
- Proceed to station $$$1$$$. This step takes $$$1$$$ second.
- Load the third candy onto the train.
- Proceed to station $$$2$$$. This step takes $$$1$$$ second.
- Deliver the third candy.

Hence, the train needs $$$5$$$ seconds to complete the tasks.

If the train were to start at station $$$2$$$, however, it would need to move to station $$$1$$$ before it could load the first candy, which would take one additional second. Thus, the answer in this scenario is $$$5+1 = 6$$$ seconds.

Info

Provider CodeForces

Origin Codeforces Round #542 [Alex Lopashev Thanks-Round] (Div. 1)

Code CF1129A2

Tags

brute forcegreedy

Submitted 41

Passed 13

AC Rate 31.71%

Date 03/04/2019 16:52:09

Related