• Tidak ada hasil yang ditemukan

Aut´ omatas con pila no-deterministas (AFPN)

5. Aut´ omatas con pila 143

5.2. Aut´ omatas con pila no-deterministas (AFPN)

∆(q0, a, z0) = (q0, Az0),

∆(q0, b, z0) = (q0, Bz0),

∆(q0, c, z0) = (q2, z0) (para aceptar la cadena c),

∆(q0, a, A) = (q0, AA),

∆(q0, a, B) = (q0, AB),

∆(q0, b, A) = (q0, BA),

∆(q0, b, B) = (q0, BB),

∆(q0, c, A) = (q1, A),

∆(q0, c, B) = (q1, B),

∆(q1, a, A) = (q1,λ),

∆(q1, b, B) = (q1,λ),

∆(q1,λ, z0) = (q2, z0).

Ejercicios de la secci´on 5.1

➀ Dise˜nar AFPD que acepten los siguientes lenguajes sobreΣ={a, b}:

(i) L={aib2i:i≥1}.

(ii) L={a2ibi:i≥1}.

➁ Dise˜nar AFPD que acepten los siguientes lenguajes sobreΣ={0,1}:

(i) L={0i1j0i :i, j≥1}.

(ii) L={1i0j1i+j :i, j≥1}.

5.2. Aut´ omatas con pila no-deterministas (AFPN)

Un Aut´omata Finito con Pila No-Determinista (AFPN) consta de los mismos siete par´ametros de un AFPD,M = (Q, q0, F,Σ,Γ, z0,∆), pero la funci´on de transici´on∆est´a definida como:

∆:Q×(Σ∪λ)×Γ→

f(Q×Γ),

donde

f(Q×Γ) es el conjunto de subconjuntos finitos de Q×Γ. Para q∈Q,a∈Σ∪{λ} ys∈Γ,∆(q, a, s) es de la forma

∆(q, a, s) ={(p11),(p22), . . . ,(pkk)}.

El significado de esta transici´on es: al leer el s´ımbolo a sobre la cinta de entrada, la unidad de control puede pasar (aleatoriamente) a uno de los estados pi (1 ≤ i ≤ k) y se mueve a la derecha. Sobre la pila hace lo siguiente: borra el s´ımbolo s que est´a en el tope y escribe la cadena γi

(cadena que pertenece aΓ).

A diferencia de lo que sucede con los AFPD, en el modelo AFPN las transicionesλ,∆(q,λ, s), no tienen restricci´on alguna.

El lenguaje aceptado por un AFPN M se define como:

L(M) :={w∈Σ : existe un c´omputo (q0, w, z0)⊢ (p,λ,β), p∈F}.

O sea, una cadenaw es aceptada si existe por lo menos un procesamiento de w desde la configuraci´on inicial hasta una configuraci´on de aceptaci´on.

La cadenaβ que queda en la pila puede ser cualquier cadena de Γ.

EjemploDise˜nar un AFPN que acepte el lenguaje {aibi :i≥0}, sobre el alfabetoΣ={a, b}.

Soluci´on. Para aceptar la cadena vac´ıa se necesita una transici´on λdesde el estado inicial. El aut´omata presentado a continuaci´on coincide con el aut´omata del primer ejemplo de la secci´on 5.1, excepto por dicha transici´on espont´anea. M = (Q, q0, F,Σ,Γ, z0,∆) donde

Σ={a, b}, Γ={z0, A, B}, Q={q0, q1, q2}, F ={q2}, y la funci´on de transici´on es:

∆(q0,λ, z0) ={(q2, z0)} (para aceptar λ),

∆(q0, a, z0) ={(q0, Az0)},

∆(q0, a, A) ={(q0, AA)},

∆(q0, b, A) ={(q1,λ)},

∆(q1, b, A) ={(q1,λ)},

∆(q1,λ, z0) ={(q2, z0)}.

En este aut´omata el no-determinismo surge ´unicamente por la presencia simult´anea de∆(q0,λ, z0) y ∆(q0, a, z0).

5.2. AUT ´OMATAS CON PILA NO-DETERMINISTAS (AFPN) 151

EjemploDise˜nar un AFPN que acepte el lenguaje de las cadenas sobre el alfabetoΣ={a, b} con igual n´umero de aes que de bes.

Soluci´on. La idea es acumular lasaes obes consecutivas en la pila. Si en el tope de la pila hay una A y el aut´omata lee unab, se borra la A; similar- mente, si en el tope de la pila hay unaB y el aut´omata lee una a, se borra laB. La cadena de entrada ser´a aceptada si es procesada completamente y en la pila s´olo queda el marcador de fondoz0. S´olo se requieren dos estados.

Concretamente, M = (Q, q0, F,Σ,Γ, z0,∆), donde Σ={a, b},

Γ={z0, A, B}, Q={q0, q1}, F ={q1}, y la funci´on de transici´on est´a dada por:

∆(q0, a, z0) ={(q0, Az0)},

∆(q0, b, z0) ={(q0, Bz0)},

∆(q0, a, A) ={(q0, AA)},

∆(q0, b, B) ={(q0, BB)},

∆(q0, a, B) ={(q0,λ)},

∆(q0, b, A) ={(q0,λ)},

∆(q0,λ, z0) ={(q1, z0)}.

El no-determinismo se presenta ´unicamente por la presencia simult´anea de

∆(q0, a, z0),∆(q0, b, z0) y ∆(q0,λ, z0).

En contraste con lo que sucede con los modelos AFD y AFN, los modelos de aut´omata con pila determinista (AFPD) y no-determinista (AFPN) no resultan ser computacionalmente equivalentes: existen lenguajes aceptados por aut´omatas AFPN que no pueden ser aceptados por ning´un AFPD. Un ejemplo concreto es el lenguaje L={wwR:w∈Σ}. Como se mostrar´a a continuaci´on, se puede construir un aut´omata con pila no-determinista para aceptar a L, pero no es posible dise˜nar ning´un AFPD que lo haga. La demostraci´on de esta imposibilidad es bastante complicada y no la podemos presentar en el presente curso.

EjemploDise˜nar un AFPN que acepte el lenguajeL={wwR:w∈Σ}, donde Σ={a, b}. No es dif´ıcil ver queL es el lenguaje de los pal´ındromos de longitud par.

Soluci´on. En el ´ultimo ejemplo de la secci´on 5.1 se construy´o un AFPD que acepta el lenguaje {wcwR : w ∈ {a, b}}. El lenguaje L del presente ejemplo es similar, excepto que ya no aparece el separadorcentrew ywR. El no-determinismo se puede usar para permitirle al aut´omata la opci´on de

“adivinar” cu´al es la mitad de la cadena de entrada. Si acierta, proceder´a a comparar el resto de la cadena de entrada con los s´ımbolos acumulados en la pila. Si no acierta, el aut´omata continuar´a acumulando s´ımbolos en la pila y no llegar´a a un estado de aceptaci´on. Si la cadena de entrada tiene la forma deseada, entre todos los c´omputos posibles estar´a aqu´el en el que el aut´omata adivina correctamente cu´ando ha llegado a la mitad de la cadena.

M se define como M = (Q, q0, F,Σ,Γ, z0,∆) donde Σ={a, b},

Γ={z0, A, B}, Q={q0, q1, q2}, F ={q2}, y la funci´on de transici´on est´a dada por:

∆(q0, a, z0) ={(q0, Az0)},

∆(q0, b, z0) ={(q0, Bz0)},

∆(q0,λ, z0) ={(q2, z0)} (para aceptar λ),

∆(q0, a, A) ={(q0, AA),(q1,λ)},

∆(q0, a, B) ={(q0, AB)},

∆(q0, b, A) ={(q0, BA)},

∆(q0, b, B) ={(q0, BB),(q1,λ)},

∆(q1, a, A) ={(q1,λ)},

∆(q1, b, B) ={(q1,λ)},

∆(q1,λ, z0) ={(q2, z0)}.

Entre estas transiciones se destacan

∆(q0, a, A) ={(q0, AA),(q1,λ)},

∆(q0, b, B) ={(q0, BB),(q1,λ)}

las cuales le permiten al aut´omata una opci´on no-determinista: o seguir acumulando s´ımbolos en la pila, en el estadoq0, o suponer que se ha llegado a la mitad de la cadena de entrada. En este ´ultimo caso, la unidad de control

5.2. AUT ´OMATAS CON PILA NO-DETERMINISTAS (AFPN) 153 pasa al estado q1 y comienza a borrar los s´ımbolos ya almacenados en la pila.

Ejercicios de la secci´on 5.2

➀ Dise˜nar APFN que acepten los siguientes lenguajes:

(i) L={0i1j :i, j≥0, i̸=j}, sobre Σ={0,1}.

(ii) L={aibj :i≥j≥0}.

!(iii) L={a2ib3i :i≥0}, sobre Σ={a, b}.

!(iv) L={0i1j : 0≤i≤j≤2i}, sobre Σ={0,1}.

➁ Como se demostr´o en la secci´on 4.13, el lenguaje L={aibici :i≥0}

no es LIC y, por consiguiente, no puede ser aceptado por ning´un aut´omata con pila. No obstante, podr´ıamos concebir el siguiente plan para aceptar a L: acumular en la pila dos Aes por cada a le´ıda en la cinta, borrar luego una A por cada b le´ıda y, finalmente, borrar una A por cada c. Si la cadena de entrada es de la forma aibici, se llegar´a al marcador de fondo z0 en el preciso momento en el que se consume completamente la entrada. Concretamente,M est´a definido como M = (Q, q0, F,Σ,Γ, z0,∆) donde

Σ={a, b, c}, Γ={z0, A},

Q={q0, q1, q2, q3, q4}, F ={q4},

y la funci´on de transici´on est´a dada por:

∆(q0,λ, z0) ={(q4, z0)} (para aceptar λ),

∆(q0, a, z0) ={(q1, AAz0)},

∆(q1, a, A) ={(q1, AAA)},

∆(q1, b, A) ={(q2,λ)},

∆(q2, b, A) ={(q2,λ)},

∆(q2, c, A) ={(q3,λ)},

∆(q3, c, A) ={(q3,λ)},

∆(q3,λ, z0) ={(q4, z0)}.

¿Acepta este aut´omata el lenguaje{aibici :i≥0}? En caso contrario,

¿qu´e lenguaje acepta?