from recognizers.automata.automaton import State, Symbol
from recognizers.automata.finite_automaton import (
    FiniteAutomatonContainer,
    FiniteAutomatonTransition
)

def a5_dfa() -> tuple[FiniteAutomatonContainer, None]:
    # Create 5 states (q0 through q4)
    q0, q1, q2, q3, q4 = map(State, range(5))
    
    # Create binary alphabet symbols (0 and 1)
    s0, s1 = map(Symbol, range(2))  # s0 represents "0", s1 represents "1"
    
    # Create automaton container with 5 states and binary alphabet
    M = FiniteAutomatonContainer(
        num_states=5,
        alphabet_size=2,
        initial_state=q0
    )
    
    # Add transitions from state 0
    M.add_transition(FiniteAutomatonTransition(q0, s0, q1))  # 0 -> 1 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q0, s1, q1))  # 0 -> 1 on symbol "1"
    
    # Add transitions from state 1
    M.add_transition(FiniteAutomatonTransition(q1, s0, q2))  # 1 -> 2 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q1, s1, q2))  # 1 -> 2 on symbol "1"
    
    # Add transitions from state 2
    M.add_transition(FiniteAutomatonTransition(q2, s0, q3))  # 2 -> 3 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q2, s1, q0))  # 2 -> 0 on symbol "1"
    
    # Add transitions from state 3
    M.add_transition(FiniteAutomatonTransition(q3, s0, q4))  # 3 -> 4 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q3, s1, q3))  # 3 -> 3 on symbol "1"
    
    # Add transitions from state 4
    M.add_transition(FiniteAutomatonTransition(q4, s0, q0))  # 4 -> 0 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q4, s1, q4))  # 4 -> 4 on symbol "1"
    
    # Set state 0 as accepting state
    M.add_accept_state(q0)
    
    return M, None


def a5_two_zeros_dfa() -> tuple[FiniteAutomatonContainer, None]:
    q0, q1, q2, q3 = map(State, range(4))
    
    # Create binary alphabet symbols (0 and 1)
    s0, s1 = map(Symbol, range(2))  # s0 represents "0", s1 represents "1"
    
    # Create automaton container with 5 states and binary alphabet
    M = FiniteAutomatonContainer(
        num_states=4,
        alphabet_size=2,
        initial_state=q0
    )
    
    # Add transitions from state 0
    M.add_transition(FiniteAutomatonTransition(q0, s0, q1))  # 0 -> 1 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q0, s1, q1))  # 0 -> 1 on symbol "1"
    
    # Add transitions from state 1
    M.add_transition(FiniteAutomatonTransition(q1, s0, q2))  # 1 -> 2 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q1, s1, q2))  # 1 -> 2 on symbol "1"
    
    # Add transitions from state 2
    M.add_transition(FiniteAutomatonTransition(q2, s0, q3))  # 2 -> 3 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q2, s1, q0))  # 2 -> 0 on symbol "1"
    
    # Add transitions from state 3
    M.add_transition(FiniteAutomatonTransition(q3, s0, q0))  # 3 -> 0 on symbol "0"
    M.add_transition(FiniteAutomatonTransition(q3, s1, q3))  # 3 -> 3 on symbol "1"
    
    # Set state 0 as accepting state
    M.add_accept_state(q0)
    
    return M, None
