public void construir_afd() { Estado inicio = new Estado(0); afd.addEstados(inicio); afd.setBegin(inicio); afd.setAlphabet(alphabet); HashSet <HashSet <Estado> > cerraduras = new HashSet <HashSet <Estado> >(); Queue <HashSet <Estado> > pila = new Queue <HashSet <Estado> >(); int identificador = 0; LinkedList <Estado> lista_inicial = new LinkedList <Estado>(); lista_inicial.AddLast(afn.getBegin()); HashSet <Estado> cerradura_inicial = e_cerradura(lista_inicial); foreach (Estado final in afn.getEstadosAceptacion()) { if (cerradura_inicial.Contains(final)) { afd.addEstadosAceptacion(inicio); } } pila.Enqueue(cerradura_inicial); while (pila.Count() > 0) { HashSet <Estado> aux = pila.Dequeue(); foreach (string id in alphabet) { LinkedList <Estado> res_mueve = mueve(aux, id); HashSet <Estado> res_cerradura = new HashSet <Estado>(); res_cerradura = e_cerradura(res_mueve); Estado anterior = afd.getEstados().ElementAt(identificador); if (res_cerradura.Count() > 0) { if (existe_estado(cerraduras, res_cerradura)) { LinkedList <Estado> estados_actuales = afd.getEstados(); Estado actual = anterior; Estado siguiente = estados_actuales.ElementAt(posicion_estado(cerraduras, res_cerradura) + 1); actual.setTransitions(new Transition(actual, siguiente, id)); } else { cerraduras.Add(res_cerradura); pila.Enqueue(res_cerradura); Estado agregar = new Estado(cerraduras.Count()); anterior.setTransitions(new Transition(anterior, agregar, id)); afd.addEstados(agregar); foreach (Estado e in afn.getEstadosAceptacion()) { if (res_cerradura.Contains(e)) { if (!afd.getEstadosAceptacion().Contains(agregar)) { afd.addEstadosAceptacion(agregar); } } } } } } identificador++; } afd.setId(id); Form1.automatons.AddLast(afd); afd.setType("AFD"); Graphviz g = new Graphviz(); g.graph_automaton2(generarDOT(id + " : AFD", afd)); }