编译原理课设 LL1语法分析器,注释掉的一部分代码是可以扩展的部分
1
设计并实现含多条简单赋值语句的语法分析程序 要求有一定的出错提示与错误恢复功能 参考教材附录C 2 注意与实验1的衔接 提交内容包括:程序 各种测试结果的截图(存到word文档中)
2021-10-17 22:38:33 46KB 编译原理 语法分析
1
课程报告,c++实现
2021-10-14 14:02:34 2.55MB 编译原理 词法分析器 语法分析器
1
目的:熟练掌握自上而下的语法分析方法,并能用程序实现。 要求: 1. 使用的文法如下: E TE E + TE | T FT T * FT | F (E) | id 2. 对于任意给定的输入串(词法记号流)进行语法分析,递归下降方法和非递归预测分析方法可以任选其一来实现。 3. 要有一定的错误处理功能。即对错误能提示,并且能在一定程度上忽略尽量少的记号来进行接下来的分析。可以参考书上介绍的同步记号集合来处理。 可能的出错情况:idid*id#, id**id#, (id+id#, +id*+id# …… ……
2021-10-13 18:00:03 8.26MB c++ 编译技术 大连理工 第四次上机
1
1. 使用的文法如下: E ® TE ¢ E ¢ ® + TE ¢ | e T ® FT ¢ T ¢ ® * FT ¢ | e F ® (E) | id 2. 对于任意给定的输入串(词法记号流)进行语法分析,递归下降方法和非递归预测分析方法可以任选其一来实现。 3. 要有一定的错误处理功能。即对错误能提示,并且能在一定程度上忽略尽量少的记号来进行接下来的分析。可以参考书上介绍的同步记号集合来处理。 可能的出错情况:idid*id, id**id, (id+id, +id*+id …… 4. 输入串以#结尾,输出推导过程中使用到的产生式。例如: 输入:id+id*id# 输出:E ® TE ¢ T ® FT ¢ F ® id E ¢ ® + TE ¢ T ® FT ¢ …… 如果输入串有错误,则在输出中要体现是跳过输入串的某些记号了,还是弹栈,弹出某个非终结符或者是终结符了,同时给出相应的出错提示信息。比如: idid*id对应的出错信息是:“输入串跳过记号id,用户多输入了一个id”; id**id对应的出错信息是:“弹栈,弹出非终结符F,用户少输入了一个id” (id+id对应的出错信息是:“弹栈,弹出终结符 ) ,用户少输入了一个右括号(或者说,括号不匹配)”
2021-10-13 16:59:39 10KB 编译原理
1
编译原理 语法分析 词法分析 源代码 报告可以直接当作业交 这个是我的当时得了优 更多报告 http://hi.baidu.com/yanzi52351
2021-10-11 19:10:40 364KB 编译原理 语法分析 词法分析 源代码
1
非常非常不错的语法分析器实验报告 语法分析器 实验报告 词法分析器 编译原理
2021-10-11 13:05:06 85KB 编译原理 实验报告
编译原理实验 词法分析器 语法分析器 完美代码 完美实验
2021-10-07 15:40:13 1.9MB 语法分析器
1
编译原理课设内容,代码可读性高,关键地方都有注释 对词法分析器各函数说明: void preInit(); //初始化关键字和关键状态 void init(); //对正规文法初始化 void inputEX(string rule); //存储三型文法进入数据结构 set Closure(FA nfa, char st); //对一个状态求闭包 set unionSet(sets1,sets2); //加入闭包结果 set e_move(FA nfa,char st, char ch); //使用子集法的move操作 bool equalSet(set s1, set s2); //使用子集法时若产生相同状态则合并 void createNFA(string express); //产生式->DFA FA createDFA(FA nfa); //NFA->DFA bool isLetter(char ch); //判断是否是数字 bool isDigit(char ch); //判断是否是字母 map getTrans(char nowNode); //从DFA中获得转换关系 Ans runDFA(string str,int pos,int line); //启动识别源程序 对语法分析器各函数说明: void init(); //对正规文法初始化 void initVt(); //初始化所有终结符 void inputEX(string rule); //存储二型文法进入数据结构 void calFisrt(); //计算FIRST集合 void calFollow(); //计算FOLLOW集合 void calSelect(); //计算SELECT集合 int get_column(string target); //得到终结符在预测分析表的列标 int get_row(string target); //得到非终结符在预测分析表的行标 void create_table(); //建立预测分析表 void print_table(); //打印预测分析表(由于预测分析表过于庞大,在程序中被注释) vector split(const string& str, const string& delim); //处理一个token void deal_tokens(); //对词法分析器得到的token表进行处理
2021-09-27 09:05:00 851KB 编译原理 词法分析 LL(1)语法分析
1
编译原理及实现 词法分析 语法分析 TESTmachine函数 完整 附录C,附录D,附录E
2021-09-24 08:16:29 8KB 编译原理 词法 语法分析 TESTmachine
1