from recognizers.automata.automaton import State, Symbol
from recognizers.automata.reserved import ReservedSymbol
from recognizers.automata.pushdown_automaton import (
    PushdownAutomatonContainer,
    PushdownAutomatonTransition,
    StackSymbol
)

def marked_reversal_pda() -> tuple[PushdownAutomatonContainer, list[str]]:
    q0, q1, q2, q3 = map(State, range(4))
    a, b, m = map(Symbol, range(3))
    S, A, B = map(StackSymbol, range(3))
    M = PushdownAutomatonContainer(
        num_states=4,
        alphabet_size=3,
        stack_alphabet_size=3,
        initial_state=q0,
        initial_stack_symbol=S,
        accept_state=q3
    )
    M.add_transition(PushdownAutomatonTransition(q0, a, q1, S, (A,)))
    M.add_transition(PushdownAutomatonTransition(q0, b, q1, S, (B,)))
    M.add_transition(PushdownAutomatonTransition(q1, a, q1, A, (A, A)))
    M.add_transition(PushdownAutomatonTransition(q1, a, q1, B, (B, A)))
    M.add_transition(PushdownAutomatonTransition(q1, b, q1, A, (A, B)))
    M.add_transition(PushdownAutomatonTransition(q1, b, q1, B, (B, B)))
    M.add_transition(PushdownAutomatonTransition(q1, m, q2, A, (A,)))
    M.add_transition(PushdownAutomatonTransition(q1, m, q2, B, (B,)))
    M.add_transition(PushdownAutomatonTransition(q2, a, q3, A, ()))
    M.add_transition(PushdownAutomatonTransition(q2, b, q3, B, ()))
    M.add_transition(PushdownAutomatonTransition(q3, a, q3, A, ()))
    M.add_transition(PushdownAutomatonTransition(q3, b, q3, B, ()))
    M.add_transition(PushdownAutomatonTransition(q0, m, q3, S, ()))

    alphabet = [str(x) for x in list(range(M._alphabet_size))]
    return M, alphabet