#P6255. [ICPC 2019 WF] Dead-End Detector

[ICPC 2019 WF] Dead-End Detector

题目背景

Warning: If you submit a malicious program, you will be banned.

警告:恶意提交本题将被封号。

题目描述

The council of your home town has decided to improve road sign placement,especially for dead ends. They have given you a road map, and you must determine where to put up signs to mark the dead ends. They want you to use as few signs as possible.

The road map is a collection of locations connected by two-way streets. The following rule describes how to obtain a complete placement of dead-end signs. Consider a street SS connecting a location xx with another location. The xx-entrance of SS gets a dead-end sign if, after entering SS from xx, it is not possible to come back to xx without making a U-turn. A U-turn is a 180-degree turn immediately reversing the direction.

To save costs, you have decided not to install redundant dead-end signs, as specified by the following rule. Consider a street SS with a dead-end sign at its xx-entrance and another street TT with a dead-end sign at its yy-entrance. If, after entering SS from xx, it is possible to go to yy and enter TT without making a U-turn, the dead-end sign at the yy-entrance of TT is redundant. See Figure E.1 for examples.

Figure E.1: Illustration of sample inputs, indicating where non-redundant dead-end signs are placed.

输入格式

The first line of input contains two integers nn and mm, where nn (1n5×105)(1 \leq n \leq 5\times10^5) is the number of locations and mm (0m5×105)(0 \leq m \leq 5 \times 10^5) is the number of streets. Each of the following mm lines contains two integers vv and ww (1v<wn)(1 \leq v \lt w \leq n) indicating that there is a two-way street connecting locations vv and ww. All location pairs in the input are distinct.

输出格式

On the first line, output kk, the number of dead-end signs installed. On each of the next kk lines, output two integers vv and ww marking that a dead-end sign should be installed at the vv-entrance of a street connecting locations vv and ww. The lines describing dead-end signs must be sorted in ascending order of vv-locations,breaking ties in ascending order of ww-locations.

6 5
1 2
1 3
2 3
4 5
5 6

2
4 5
6 5
8 8
1 2
1 3
2 3
3 4
1 5
1 6
6 7
6 8

3
1 5
1 6
3 4

提示

Source: ICPC World Finals 2019 Problem E.