ниже приведена грамматика, которую я использую для языка калькулятора, и моя попытка найти следующий набор и первый набор грамматики.
Я хотел бы помочь в выяснении того, что я делаю неправильно, пытаясь понять эти наборы, потому что я чувствую, что делаю их неправильно (по крайней мере, для следующих наборов)
Грамматика
программа → stmt_list $$$
stmt_list → stmt stmt_list | ε
stmt → id = expr | входной идентификатор | напечатать expr
expr → term term_tail
term_tail → добавить op term term_tail | ε
term → factor fact_tail
fact_tail → mult_op fact fact_tail | ε
фактор → ( expr ) | номер | id
add_op → + | -
mult_op → * | / | // | %
Первый набор
first(p) = {id, input, print}
first(stmt_list) = {id, input, print, e}
first(s) = {id, input, print}
first(expr ) = {(, id, number}
first(term_tail) = {+, -, e}
first(term) = {(, id, number}
first(fact_tail) = {, /, //, %, e}
first(factor) = {(, id, number}
first(add_op) = {+, -}
first(mult_op) = { em>, /, //, %}
Следовать за набором
follow(p) = {$}
follow(stmt_list) = {$}
follow(stmt) = {id, input, print}
follow(expr) = {(, id, number, ) , input, print, , /, //, %}
follow(term_tail) = {), (, id, number, print, input}
follow(term) = {+, -}
follow(factor) = {, /, //, %}
follow(add_op) = {}follow(mult_op) = {}
follow(fact_tail) = {*,/ , //, %, +, -}