【编译原理】FIRSTVT和LASTVT求法

FIRSTVT

找FIRSTVT的三条规则:如果要找A的FIRSTVT,A的候选式中出现:
A->a…,即以终结符开头,该终结符入FIRSTVT
A->B…,即以非终结符开头,该非终结符的FIRSTVT入A的FIRSTVT
A->Ba…,即以非终结符终结符开头,则该终结符入FIRSTVT

LASTVT

找LASTVT的三条规则:如果要找A的LASTVT,A的候选式中出现:
A->…a,即以终结符结尾,该终结符入LASTVT
A->…B,即以非终结符结尾,该非终结符的LASTVT入A的LASTVT
A->…aB,即以终结符非终结符结尾,则终结符入LASTVT


用一道例题检验对概念的理解:

已给文法: G[S]:
S → a|b|(B)
A → S, A|S
B → A

求所有非终结符的 FIRSTVT,LASTVT 集

解析:
(1)只要是让求 FIRSTVT,LASTVT 集,则该文法就隐含条件为算符优先文法。

(2)算符优先文法的特点是:不会出现两个相邻的非终结符,即两个非终结符中间夹着一个终结符。如果第一个是终结符则第二个是非终结符。

答案:
在这里插入图片描述

  • 30
    点赞
  • 110
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值