def hopcroft_minimization(states, alphabet, start_state, accept_states, transitions):
    # 初始划分：接受状态和非接受状态
    P = [set(accept_states), set(states) - set(accept_states)]
    # 初始化等待处理的集合，选择较小的那个子集开始处理
    W = [set(accept_states)] if len(accept_states) < len(states) - len(accept_states) else [set(states) - set(accept_states)]
    
    while W:
        A = W.pop()
        for c in alphabet:
            # 计算在输入 c 下可以到达 A 的状态集合 X
            X = set(s for s in states if transitions.get((s, c), None) in A)
            # 更新 P 和 W
            newP = []
            for Y in P:
                # 交集（可以到达 A 的状态）
                intersect = X & Y
                # 差集（不可以到达 A 的状态）
                difference = Y - X
                # 需要进一步细分
                if intersect and difference:
                    newP.append(intersect)
                    newP.append(difference)
                    # 更新 W，加入较小的部分
                    if Y in W:
                        W.remove(Y)
                        W.append(intersect)
                        W.append(difference)
                    else:
                        W.append(intersect if len(intersect) <= len(difference) else difference)
                else:
                    newP.append(Y)
            P = newP
    
    # 构建最小化的 DFA
    # 每个等价类选择一个代表状态
    min_dfa_states = {frozenset(block): idx for idx, block in enumerate(P)}
    min_dfa_start_state = next(min_dfa_states[frozenset(block)] for block in P if start_state in block)
    min_dfa_accept_states = {min_dfa_states[frozenset(block)] for block in P if block & accept_states}
    min_dfa_transitions = {}

    for block in P:
        representative = next(iter(block))
        for c in alphabet:
            target = transitions.get((representative, c), None)
            if target is not None:
                min_dfa_transitions[(min_dfa_states[frozenset(block)], c)] = min_dfa_states[frozenset(next(b for b in P if target in b))]

    return min_dfa_states, min_dfa_start_state, min_dfa_accept_states, min_dfa_transitions

if __name__ == '__main__':
    # test it can simplify the automaton
    states = {'A', 'B', 'C', 'D', 'E', 'F'}
    alphabet = {'0', '1'}
    start_state = 'A'
    accept_states = {'C', 'D'}
    transitions = {
        ('A', '0'): 'A', ('A', '1'): 'B',
        ('B', '0'): 'B', ('B', '1'): 'A',
        ('C', '0'): 'C', ('C', '1'): 'D',
        ('D', '0'): 'D', ('D', '1'): 'C',
        ('E', '0'): 'E', ('E', '1'): 'F',
        ('F', '0'): 'F', ('F', '1'): 'E',
    }

    min_states, min_start_state, min_accept_states, min_transitions = hopcroft_minimization(
        states, alphabet, start_state, accept_states, transitions)

    print("Minimized States:", min_states)
    print("Minimized Start State:", min_start_state)
    print("Minimized Accept States:", min_accept_states)
    print("Minimized Transitions:", min_transitions)