ll1文法】的更多相关文章

上篇文章[编译原理]语法分析--自上向下分析 分析了LL1语法,文章最后说给出栗子,现在补上去. 说明: 这个语法分析器是利用LL1分析方法实现的. 预测分析表和终结符以及非终结符都是针对一个特定文法定义好的. 输入的分析串必须以 # 开头和结尾. 原始文法: E -> E + T | T T -> T * T | F F -> (E) | i 消除左递归之后 E -> TE' E' -> +TE' | e T -> FT' T' -> *FT' | e F -&…
LL(1)文法求算数表达式的值递归子程序法 分析过程: 表达式文法G[E]:E->E+T|E-T|TT->T*F|T/F|T%F|FF->N^F|NN->(E)|NUM|+NUM|-NUM 消除左递归.左公共因子E ->TE'E'->+TE'|-TE'|εT ->FT'T'->*FT'|/FT'|%FT'|εF ->NF'F'->^F|εN->(E)|NUM|+NUM|-NUM FIRST集和FOLLOW集 LL(1)分析表 (应该没错吧……
import hjzgg.analysistable.AnalysisTable; import hjzgg.first.First; import hjzgg.follow.Follow; import hjzgg.treenode.TreeNode; import java.awt.BorderLayout; import java.awt.Color; import java.awt.Dimension; import java.awt.Font; import java.awt.Grap…
import hjzgg.first.First; import hjzgg.follow.Follow; import hjzgg.tablenode.TableNode; import hjzgg.treenode.TreeNode; import java.util.ArrayList; import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; import java.util.Stack; im…
import hjzgg.first.First; import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; import java.util.TreeMap; import java.util.TreeSet; public class Follow { private Map<String, Set<Character>> first = null; private Map<St…
import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; import java.util.TreeMap; import java.util.TreeSet; public class First { private Map<String, Set<Character>> first = new TreeMap<String, Set<Character>>();…
<program>-><external_declaration> | <program> <external_declaration> <external_declaration> -><function_definition> | <declaration> <function_definition> -><type_specifier> <declarator>…
语法分析的两种思维方式:1:自顶向下分析 :从语法树的根部推下来一直推到需要确认的终结符号串为止:就是为了找到一个符号串的最左推导 自顶向下分析,因为文法有些是以非终结符开头的另外文法中还可能含有右部为空的推导:(为了能让机器决定下 一步采取那个推导式子)前者情况决定需要求所谓的FIRST集.后者决定需要求FOLLOW集(例如F->空|非空: 那么当能推导 过程中遇到F时因为F可能为空所以就需要求一下F后边可能后随的符号即FLLOW集以判断F是否可以取空:当然此时必须要求 F的后随符号(FOLL…
对于小学四则混合运算出题软件的设计,通过分析设计要求,我觉得为了这个软件在今后便于功能上的扩充,可以利用上学期所学习的<编译原理>一课中的LL1语法分析及制导翻译的算法来实现.这样做的好处有以下几点: 1. 由于LL1制导翻译是一项成熟且可靠的技术,并且其递归下降算法易于改编为算式生成算法: 2. 我们有系统的方法可以获得较复杂表达式的LL1文法,则可以方便地生成形式丰富的算式: 3.由于四则混合运算中需要考虑运算优先级的问题,那么采用LL1分析器可以很方便的实现计算表达式的功能: 4.当用户…
<程序>-><声明列表>|<程序><函数> <声明列表>-><声明>|<声明><声明列表> <声明>-> #include < 标识符 . h > <函数>-><修饰符><标识符><形式参数><复合语句> <修饰符>->void | int |char |float|double <…