算符优先文法的编程实现

实验三 算符优先文法的编程实现

一、实验目的

1. 通过本次实验,加深对移进规约分析法中算符优先法的理解;

2. 学习程序设计语言的语法分析器的手工编程方法。

 

二、实验内容

1. 对于任意给定的文法,判断其是否是算符优先文法。

2. 通过语法分析,生成抽象语法树,在此基础上设计并实现一个简单的计算器。

 

三、实验原理

1. 自底向上优先分析方法

也称移进-归约分析,粗略地说它的思想是对输入符号串自左向右进行扫描,并将输入符号逐个移入一个后进先出栈,边移入边分析,一旦栈顶符号串形成某个句型的句柄或可归约串时,就将该产生式的左部非终极符代替相应的右边文法符号串。

2. 算符优先分析

依照算术表达式的四则运算过程来进行语法分析,即这种分析方法要预先规定运算符(确切地说是终结符)之间的优先关系和结合性质,然后借助于这种关系来比较相邻运算符的优先级,以确定句型的“可归约串”来进行归约。

因此,算符优先分析法不是一种规范归约,在整个归约过程中起决定性作用的是相继两个终结符的优先关系。

3. 算符优先文法

首先定义一个任何产生式的右部都不含两个相继(并列)的非终结符的文法为算符文法,即算符优先文法首先应是一个算符文法;其次,还要定义任何两个可能相继出现的终结符a与b (它们之间最多插有一个非终结符)的优先关系。

4. 终结符号间优先关系的确定,用FIRSTVT集和LASTVT集计算。

 FIRSTVT集:

(1) 若有产生式P→a…或P→Qa…,则a∈FIRSTVT(P);

(2) 若a∈FIRSTVT(Q),且产生式P→Q…,则a∈FIRSTVT(P)。

LASTVT集:

(1)    若有产生式P→…a或P→…aQ,则a∈LASTVT(P);

(2)    若a∈LASTVT(Q),且P→…Q,则a∈LASTVT(P)。

 

四、算法思想

1.根据所输入文法规则,求文法中每个非终结符的FIRSTVT集和LASTVT集。

算符描述如下:

/*求 FirstVT 集的算法*/

PROCEDURE insert(P,a);  IF not F[P,a] then    begin   

        F[P,a] = true; //(P,a)进栈   end;   

Procedure FirstVT;  Begin  

for 对每个非终结符 P和终结符 a do     F[P,a] = false  for 对每个形如 P  a…或 P→Qa…的产生式 do  

Insert(P,a)  while stack  非空  begin  

  • 6
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
算符优先文法是一种用于语法分析的方法,其主要思想是根据运算符的优先级和结合性来判断表达式的正确性。在Java编程中,可以通过实现算法优先文法分析器来实现表达式的语法分析。下面是一个简单的算符优先文法分析器的设计与实现。 1. 算符优先文法分析器的设计 算符优先文法分析器的设计主要包括以下几个方面: - 根据算符的优先级和结合性,定义终结符和终结符的关系; - 根据文法规则,设计分析表,并使用分析表对输入的表达式进行分析; - 实现GUI界面,通过文本框和按钮等控件,实现用户输入表达式和分析结果的输出。 2. 算符优先文法分析器的实现 算符优先文法分析器的实现主要包括以下几个步骤: - 定义终结符和终结符的关系 在算符优先文法中,将运算符分为三类:左括号、右括号和运算符。其中,左括号可以看作是最高优先级的运算符,右括号可以看作是最低优先级的运算符,而其他的运算符根据优先级和结合性确定优先级大小。根据这些规则,可以定义终结符和终结符的关系,如下所示: - E → E + T | E - T | T - T → T * F | T / F | F - F → ( E ) | i 其中,E、T、F、+、-、*、/、(、)、i 分别表示终结符和终结符。 - 设计分析表 根据算符优先文法的规则,可以设计分析表。分析表的设计主要包括以下几个步骤: - 构造符号表,将终结符和终结符按照优先级从高到低排序,并将左括号和右括号放在最高和最低位置; - 定义关系矩阵,将符号表中的符号两两组合,根据算符优先文法的规则定义它们之间的关系; - 根据关系矩阵,构造分析表,包括移进表、归约表和出错表。 例如,对于上述算符优先文法,其分析表如下所示: | | + | - | * | / | ( | ) | i | $ | |----|----|----|----|----|----|----|----|----| | + | > | > | < | < | < | > | < | > | | - | > | > | < | < | < | > | < | > | | * | > | > | > | > | < | > | < | > | | / | > | > | > | > | < | > | < | > | | ( | < | < | < | < | < | = | < | | | ) | > | > | > | > | | > | | > | | i | > | > | > | > | | > | | > | | $ | < | < | < | < | < | | < | = | 其中,>表示移进,<表示归约,并且表格中的空格表示出错。 - 实现GUI界面 在Java编程中,可以使用Swing或JavaFX等GUI库来实现算符优先文法分析器的GUI界面。具体实现步骤如下: - 使用JFrame类或Stage类创建主窗口; - 使用JPanel类或Group类创建布局,添加文本框、按钮等控件; - 实现按钮的事件处理程序,获取用户输入的表达式,进行语法分析,输出分析结果。 3. 算符优先文法分析器的注意事项 在实现算符优先文法分析器时,需要注意以下几个问题: - 算符优先文法分析器只能处理符合文法规则的表达式,对于不合法的表达式,需要进行出错处理; - 分析表的构造需要根据具体的文法规则进行设计,构造出来的分析表在处理其他文法规则的表达式时可能会出现错误; - GUI界面的设计需要考虑用户的交互体验,包括布局、控件的大小和位置等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值