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?
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.
Respostas:
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.
fonte
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.
fonte