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

def majority_pda() -> PushdownAutomatonContainer:
    q0, q1 = map(State, range(2))
    a, b = map(Symbol, range(2))
    S, A, B = map(StackSymbol, range(3))
    M = PushdownAutomatonContainer(
        num_states=3,
        alphabet_size=2,
        stack_alphabet_size=3,
        initial_state=q0,
        initial_stack_symbol=S,
        accept_state=q1
    )
    M.add_transition(PushdownAutomatonTransition(q0, a, q0, S, (A, S)))
    M.add_transition(PushdownAutomatonTransition(q0, b, q0, S, (B, S)))
    M.add_transition(PushdownAutomatonTransition(q0, a, q0, B, ()))
    M.add_transition(PushdownAutomatonTransition(q0, b, q0, A, ()))
    M.add_transition(PushdownAutomatonTransition(q0, a, q0, A, (A, A)))
    M.add_transition(PushdownAutomatonTransition(q0, b, q0, B, (B, B)))
    M.add_transition(PushdownAutomatonTransition(q0, ReservedSymbol.EPSILON, q1, A, ()))
    M.add_transition(PushdownAutomatonTransition(q1, ReservedSymbol.EPSILON, q1, A, ()))
    M.add_transition(PushdownAutomatonTransition(q1, ReservedSymbol.EPSILON, q1, S, ()))
    return M, None