CCC '24 S4 - Painting Roads
Canadian Computing Competition: 2024 Stage 1, Senior #4
Alanna, the mayor of Kitchener, has successfully improved the city's road plan. However, a travelling salesperson from the city of RedBlue complained that the roads are not colourful enough. Alanna's second job is to paint some of the roads.
Kitchener's road plan can be represented as a collection of \(N\) intersections with \(M\) roads, where the \(i^{\text{th}}\) road connects intersections \(u_i\) and \(v_i\) . All roads are initially grey. Alanna would like to paint some of the roads in red or blue such that the following condition is satisfied:
- Whenever there is a grey road that connects \(u_i\) and \(v_i\) , there is also a path of roads from \(u_i\) to \(v_i\) such that the roads on the path alternate between red and blue, without any of the roads on this path being grey.
To lower the city's annual spending, Alanna would like to minimize the number of painted roads. Can you help Alanna design a plan that meets all the requirements?
Input Specification
The first line contains two integers \(N\) and \(M\) \((1 \le N, M \le 2 \cdot 10^5)\) .
The \(i^{\text{th}}\) of the next \(M\) lines contains two integers \(u_i\) and \(v_i\) , meaning that there exists a road from intersection \(u_i\) to intersection \(v_i\) \((1 \le u_i, v_i \le N, u_i \neq v_i)\) .
There is at most one road between any unordered pair of intersections.
The following table shows how the available 15 marks are distributed:
| Marks | Additional Constraints |
|---|---|
| 2 | There is a road connecting intersection \(i\) with intersection \(i + 1\) for all \(1 \le i < N\) (and possibly other roads). |
| 3 | We can reach any intersection from any other intersection, and \(N = M\) . |
| 3 | No road belongs to two or more simple cycles (see Definition below). |
| 7 | None |
Definition: if we denote a road between intersections \(u\) and \(v\) as \(u \leftrightarrow v\) , then a simple cycle is a sequence \(w_1 \leftrightarrow w_2 \leftrightarrow \dots \leftrightarrow w_k \leftrightarrow w_1\) where \(k \ge 3\) and all \(w_i\) are distinct.
Output Specification
Output a string of \(M\) characters, representing the paint plan. The \(i^{\text{th}}\) character should be R if the \(i^{\text{th}}\) road is to be painted red, B if \(i^{\text{th}}\) road is to be painted blue, or G (for "grey") if the \(i^{\text{th}}\) road is to be left unpainted.
Remember that you must minimize the number of painted roads while satisfying the condition. If there are multiple possible such plans, output any of them.
Sample Input 1
5 7
1 2
2 4
5 2
4 5
4 3
1 3
1 4Output for Sample Input 1
RGGRGRBExplanation of Output for Sample Input 1
A diagram of the intersections along with a valid paint plan that minimizes the number of painted roads is shown below. Note that the colours are shown on each road as R (red), B (blue), or G (grey).
All the unpainted roads satisfy the condition:
- The \(2^{\text{nd}}\) road, labelled \(\text{G}_2\) , connects intersection \(2\) with intersection \(4\) . The path through intersections \(2, 1, 4\) alternates red, blue.
- The \(3^{\text{rd}}\) road, labelled \(\text{G}_3\) , connects intersection \(5\) with intersection \(2\) . The path through intersections \(5, 4, 1, 2\) alternates red, blue, red.
- The \(5^{\text{th}}\) road, labelled \(\text{G}_5\) , connects intersection \(4\) with intersection \(3\) . The path through intersections \(4, 1, 3\) alternates blue, red.
Sample Input 2
4 2
1 2
3 4Output for Sample Input 2
BBExplanation of Output for Sample Input 2
Note that it is possible for Kitchener to be disconnected.
Comments