Exercício 04.34

Desenvolva um Autômato Finito com Movimentos Vazios (AFε) sobre o alfabeto Σ = {i, j, k}, que reconheça a linguagem L = {w | w possui kij ou kjk como prefixo, jki ou kji como subpalavra e iij ou jij como sufixo}.


Resposta

M = ({i, j, k}, {q0, q1, q2, q3, q4, q5, q6, q7, q8, q9, q10, q11, q12, q13, q14, q15, q16, q17, q18, q19, q20, q21, q22, q23, q24, q25, q26, q27}, δ, q0, {q27})

δ i j k ε
q0 - - - {q1, q5}
q1 - - {q2} -
q2 {q3} - - -
q3 - {q4} - -
q4 - - - {q9, q11}
q5 - - {q6} -
q6 - {q7} - -
q7 - - {q8} -
q8 - - - {q9, q12, q15}
q9 {q9} {q9} {q9} {q10, q14}
q10 - {q11} - -
q11 - - {q12} -
q12 {q13} - - -
q13 - - - {q18, q20}
q14 - - {q15} -
q15 - {q16} - -
q16 {q17} - - -
q17 - - - {q18, q20, q25}
q18 {q18} {q18} {q18} {q19, q23}
q19 {q20} - - -
q20 {q21} - - -
q21 - {q22} - -
q22 - - - {q27}
q23 - {q24} - -
q24 {q25} - - -
q25 - {q26} - -
q26 - - - {q27}
q27 - - - -

Recomendamos

Java Magazine Revista Segurança Digital Agenda TI