作业二(文法与语言)

1.文法G(Z):Z->aZb|ab定义的是什么样的语言?

2.写出教材22页例2.2中标识符的文法四元组形式。

3.写出下列表达式的最左推导、最右推导和语法树。

G(E):

E=> E + T | T

T=>T * F | F

F=>(E)| i

  • i*i+i
  • i+i*i
  • i+(i+i)

 注意观察最左和最右推导过程的不同,以及语法树的异同。

 

 

 

 

 

1、G(Z):Z->aZb|ab

Z->aZb->aaZbb->aaaZbbb->aaaabbbb

即文法G(Z)描述了GZ=a**nb**n

 

2、G=(VN,VT,P,S)VN={E、T、F} VT={a-z,0-9} P={E->T|ET|EF T->a-z F->0-9} S=E

 

3、①i*i+i的最左推导:E->E+T->T+T->T*F+T->F*F+T->i*F+T->i*i+T->i*i+F->i*i+i

  最右推导:E->E+T->E+F->E+i->T+i->T*F+i->T*i+i->F*i+i->i*i+i

  语法树:

 

 

 

 

i+i*i的最左推导:E->E+T->T+T->F+T->i+T->i+F*T->i+i*T->i+i*F->i+i*i

最右推导:E->E+T->E+T*F->E+T*i->E+F*i->E+i*i->T+i*i->F+i*i->i+i*i

语法树:

 

i+(i+i)的最左推导:E->E+T->T+T->F+T->i+T->i+F->i+(E)->i+(E+T)->i+(T+T)->i+(F+T)->i+(i+T)->i+(i+F)->i+(i+i)

最右推导:E->E+T->E+F->E+(E)->E+(E+T)->E+(E+F)->E+(E+i)->E+(T+i)->E+(F+i)->E+(i+i)->T+(i+i)->F+(i+i)->i+(i+i)

语法树:

 

转载于:https://www.cnblogs.com/nazhabanma/p/11514814.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值