Localizando o idioma gerado por uma gramática livre de contexto


11

Esta é uma pergunta do livro do Dragão (peço desculpas por erros de tradução, não tenho a versão em inglês):

Que idioma é gerado por esta gramática?

SaSbSbSaSϵ

Não sei o que devo fazer aqui. A definição no livro sobre idiomas diz isso (e é isso mesmo no capítulo):

um idioma é o conjunto de todas as palavras que podem ser produzidas por qualquer árvore de análise.

Portanto, se eu quiser fazer "qualquer" árvore de análise dessa gramática, posso recursivamente continuar construindo-a, usando apenas as duas primeiras regras. Pesquisei um pouco e tive a impressão de que todas as regras devem ser usadas uma vez, mas não tenho certeza. Seria muito útil se alguém fosse capaz de fornecer algumas dicas para resolver esse tipo de problema.


1
Dica: Use expressão regular
Bartosz Przybylski 18/13

Para dicas, veja as respostas abaixo. Em resposta à sua pergunta: não, não é necessário usar todas as regras pelo menos uma vez. Comece com o símbolo de início (ou axioma) e aplique as regras de reescrita até ficar apenas com símbolos de terminal (aqui em minúscula).
Hendrik Jan

supondo que a String vazia não seja um símbolo terminal, pelo que entendi, não é possível que apenas restem símbolos terminais, ou estou entendendo algo errado?
dan


SaSbSaaSbbSaabbSaabbbSaaabbba

Respostas:


6

ab

Seria muito útil se alguém fosse capaz de fornecer algumas dicas para resolver esse tipo de problema.

Não há receita única para todos aqui. É indecidível, em geral, se dois CFGs produzem o mesmo idioma ou dois CFLs são o mesmo idioma. Um método útil é tentar perceber as propriedades que permanecem invariáveis ​​durante as produções.


5

Dica: construa algumas palavras que são geradas por esta gramática. Você vê um padrão? Você pode descrever algumas propriedades de todas as palavras geradas pela gramática, apenas observando as regras? Depois de adivinhar (corretamente) o idioma gerado pela gramática, não será difícil provar isso.

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.