from collections.abc import Callable, Iterable
from typing import TypeVar

Vertex = TypeVar('Vertex')

def reachable(
    roots: Iterable[Vertex],
    successor_func: Callable[[Vertex], Iterable[Vertex]]
) -> set[Vertex]:
    agenda = list(roots)
    discovered = set(agenda)
    while agenda:
        u = agenda.pop()
        for v in successor_func(u):
            if v not in discovered:
                discovered.add(v)
                agenda.append(v)
    return discovered
