Pedro tiene un poliedro convexo de caras triangulares y quiere pintar sus caras sin que dos caras adyacentes tengan el mismo color. Dispuesto a comprar pintura, se pregunta cuál es el menor número de colores necesarios. Tras fracasar buscando la respuesta, su amigo, un turista bielorruso, le dice lo siguiente:
– “Te daré una pista para que lo puedas pintar. Si pones un vértice en cada cara y unes los vértices que estén en caras adyacentes, obtienes un grafo. Tu problema es equivalente a colorear ese grafo con el menor número de colores. Y por si no te has dado cuenta, por venir de un poliedro, el grafo será siempre cúbico, planar y tres-conexo.”
Pedro sigue sin tener ni idea, así que os ha dejado el problema a vosotros. Recordad que un grafo cúbico es aquel en que todo vértice tiene exactamente tres vecinos, un grafo planar es aquel que se puede pintar en un papel sin que dos aristas se crucen, y un grafo tres-conexo es un grafo conexo al que se le han de quitar por lo menos tres vértices para desconectarlo.
La entrada tiene diversos grafos, todos provinientes de un poliedro
como se ha descrito anteriormente. Cada grafo empieza con su número de
vértices
,
seguido de
triplas con los vecinos de cada vértice
.
Al final viene la palabra CUENTA o la palabra
PINTA. Podéis suponer
.
Los vértices se numeran desde cero.
Para cada caso de tipo CUENTA, escribid el mínimo número
de colores para pintar el grafo. Para los de tipo PINTA, a
continuación escribid los colores de los vértices en orden. Seguid
estrictamente el formato de los ejemplos.
Es conocido que todo grafo planar se puede pintar con cuatro colores o menos.
Test1: Resolver casos de tipo
CUENTA donde
.
Test2: Resolver casos de tipo
CUENTA.
Test3: Resolver casos de tipo
PINTA donde
.
Test4: Resolver casos de tipo
PINTA.
Input
4 1 2 3 0 2 3 0 1 3 0 1 2 CUENTA 6 1 2 4 0 2 5 0 1 3 2 4 5 0 3 5 1 3 4 CUENTA 8 1 2 6 0 3 7 0 3 4 1 2 5 2 5 6 3 4 7 0 4 7 1 5 6 CUENTA
Output
4 3 2
Input
4 1 2 3 0 2 3 0 1 3 0 1 2 PINTA 6 1 2 4 0 2 5 0 1 3 2 4 5 0 3 5 1 3 4 PINTA 8 1 2 6 0 3 7 0 3 4 1 2 5 2 5 6 3 4 7 0 4 7 1 5 6 PINTA
Output
4 1234 3 312312 2 12211221