Jak pokazać, że gramatyka jest niejednoznaczna?

Spisu treści:

Jak pokazać, że gramatyka jest niejednoznaczna?
Jak pokazać, że gramatyka jest niejednoznaczna?
Anonim

"Jeżeli gramatyka daje co najmniej 2 odrębne drzewo analizy lub pochodne, to gramatyka jest niejednoznaczna." Kolejna zasada: wszystkie CFG (bez zbędnych symboli) z lewostronną i prawostronną rekursywnością dla tego samego nieterminala też są niejednoznaczne.

Skąd wiesz, że gramatyka jest niejednoznaczna?

O gramatyce mówi się, że jest niejednoznaczna, jeśli istnieje więcej niż jedna skrajna lewa derywacja lub więcej niż jedna skrajna prawa derywacja lub więcej niż jedno drzewo analizy dla podanego ciągu wejściowego. Jeśli gramatyka nie jest dwuznaczna, nazywa się ją jednoznaczną. Jeśli gramatyka jest niejednoznaczna, to nie jest dobra dla konstrukcji kompilatora.

Jaki jest przykład niejednoznacznej gramatyki?

W informatyce niejednoznaczna gramatyka to gramatyka bezkontekstowa, dla której istnieje ciąg, który może mieć więcej niż jedno skrajne lewe drzewo pochodne lub drzewo analizy, podczas gdy gramatyka jednoznaczna to gramatyka bezkontekstowa, dla której każdy poprawny ciąg ma unikatowe wyprowadzenie lub drzewo analizy z lewej strony.

Jak udowodnić, że gramatyka bezkontekstowa jest niejednoznaczna?

3 Odpowiedzi

  1. Wszystkie CFG bez bezużytecznych symboli iz rekurencją lewą i prawą dla tego samego symbolu są niejednoznaczne. Ogólnie: …
  2. Aby zbadać niejednoznaczność, musisz znaleźć 2 skrajne lewe pochodne dla tego samego łańcucha (lub 2 skrajne prawe pochodne lub 2 drzewa pochodne).

Jak rozwiązać niejednoznaczną gramatykę?

Metody usuwania niejednoznaczności-

  1. Poprawiając gramatykę.
  2. Dodając reguły grupowania.
  3. Korzystając z semantyki i wybierając najbardziej sensowną analizę.
  4. Dodając reguły pierwszeństwa lub inne reguły przetwarzania zależnego od kontekstu.

Zalecana:

Interesujące artykuły
Czy kaufman kontra Lawler był prawdziwy?
Czytaj więcej

Czy kaufman kontra Lawler był prawdziwy?

Wiele lat po tym, jak Kaufman i Lawler pojawili się w „Late Night”, Lawler ujawnił, że ich spór został całkowicie zainscenizowany i że para była w rzeczywistości bliskimi przyjaciółmi, według The Los Angeles Times. To miało sens: teatralny charakter pracy Kaufmana i świata wrestlingu były meczem w raju oszustów.

Dlaczego tusz do rzęs rozmazuje się pod oczami?
Czytaj więcej

Dlaczego tusz do rzęs rozmazuje się pod oczami?

"Wilgoć i olejki z kremu pod oczy mieszają się z ciepłem i olejkami ze skóry. Ciepło to unosi się w kierunku tuszu i wpływa na formułę tuszu do rzęs, który rozkłada składniki, tworząc przerażające plamy i smugi tuszu do rzęs." Jak sprawić, by tusz do rzęs nie rozmazywał się pod oczami?

Kto jest silniejszy regieleki i regidrago?
Czytaj więcej

Kto jest silniejszy regieleki i regidrago?

Tak dobrze, jak Regidrago może wyglądać na papierze, Regieleki jest lepsze. Z 200 bazową statystyką szybkości, Regieleki jest najszybszym Pokémonem w grze. Cierpi na ten sam brak masy co Regidrago, mając tylko 50 dla obu podstawowych statystyk Obrony, ale ma też tylko 80 podstawowych HP, co czyni go jeszcze słabszym.