""""""
from typing import List, Sequence


def welsh_powell_coloring(adj_matrix: Sequence[Sequence[bool]]) -> List[int]:
    """\nadj_matrix: Sequence[Sequence[bool]]\n    """
    n = len(adj_matrix)
    if any(len(row) != n for row in adj_matrix):
        raise ValueError("adj_matrix must be square")

    degrees = [(i, sum(1 for j in range(n) if adj_matrix[i][j])) for i in range(n)]
    degrees.sort(key=lambda x: x[1], reverse=True)

    colors = [-1] * n
    current_color = 0

    for v, _deg in degrees:
        if colors[v] != -1:
            continue
        
        colors[v] = current_color

        for w, _deg_w in degrees:
            if colors[w] != -1:
                continue
            if all(not adj_matrix[w][u] for u in range(n) if colors[u] == current_color):
                colors[w] = current_color

        current_color += 1

    return colors


def color_classes_from_assignments(colors: Sequence[int]) -> List[List[int]]:
    """\ncolors: Sequence[int]\n    """
    n = len(colors)
    if n == 0:
        return []

    max_color = max(colors)
    classes: List[List[int]] = [[] for _ in range(max_color + 1)]
    for v, c in enumerate(colors):
        if c < 0:
            raise ValueError(f"Vertex {v} has negative color {c}")
        classes[c].append(v)
    return classes
