翻译布尔表达式 SDUT OJ 编译原理练习题 拉链回填

本文介绍了布尔表达式的翻译方法,重点讨论了拉链回填技术。通过对不同样例的分析,解释了真假链出口的确定原则,并提供了相关样例的解题思路。

翻译布尔表达式

Description

大家都学过了布尔表达式的翻译,其中有一个拉链-回填技术,这次我们就练习这个技术。

Input

输入为一行字符串,例如: a < b or c < d and e < f

每个符号都用空格间隔。

其中逻辑运算符包含 and 和 or , 关系运算符包含 < 、> 、<= 、 >= 、== 、 != 。

Output

 假链跳到0,真链跳到1,表达式序号从100开始排。

Sample

Input 

a < b or c < d and e < f

Output 

100(j<,a,b,1)
101(j,_,_,102)
102(j<,c,d,104)
103(j,_,_,0)
104(j<,e,f,100)
105(j,_,_,103)

解题思路:

本题难点是在假链出口,
观察下方例子可以发现,
假链出口0 需要在 最早没机会继续翻译下去的地方,
就是说如果在这里为假了,那后面的都不需要进行翻译了,那这里就是假链出口。
真链一直顺序继承前面的真链出口就可以,假链变化较复杂。

真链出口1 是出现 可以直接令整个表达式串为真 的表达式时写入的
假链出口0 是出现 可以直接令整个表达式串为假,不需要再往后判断的时候 写入的
由此可知,
可以作为真链出口1的有:
(1)每一个or左边表达式为真时的输出 (2)最后一个and的右边表达式(在or或end的左边)为真的输出
可以作为假链出口0的有:
(1)每一个and的左边表达式为假的输出 (2)最后一个or右边表达式(在or或end的左边)为假的输出


例1 a < b or c < d and e < f
100(j<,a,b,1)
101(j,_,_,102)
102(j<,c,d,104)
103(j,_,_,0)
104(j<,e,f,100)
105(j,_,_,103)


例2 a < b or c < d
100(j<,a,b,1)
101(j,_,_,102)
102(j<,c,d,100)
103(j,_,_,0)


例3 a < b and c < d and e < f
100(j<,a,b,102)
101(j,_,_,0)
102(j<,c,d,104)
103(j,_,_,101)
104(j<,e,f,1)
105(j,_,_,103)


例4 a < b or c < d and e < f or g < h
100(j<,a,b,1)
101(j,_,_,102)
102(j<,c,d,104)
103(j,_,_,106)
104(j<,e,f,100)
105(j,_,_,103)
106(j<,g,h,104)
107(j,_,_,0)

⒈ 题目 分析对象的BNF定义如下: 〈算术表达式〉∷=〈项〉|〈算术表达式〉+〈项〉|〈算术表达式〉-〈项〉 〈项〉∷=〈因式〉|〈项〉*〈因式〉|〈项〉/〈因式〉 〈因式〉∷=〈变量〉│(〈算术表达式〉) 〈变量〉∷=〈字母〉 〈字母〉∷=A|B|C|D|E|F|G|H|I|J|K|L|M|N|O|P|Q|R|S|T|U|V|W|X|Y|Z (a)总程序过程 (b) ( E过程)算术表达式处理 (c)项处理(T过程) (d)因式处理过程)(F过程) (e) (f) 图2-7-5 递归下降法分析表达式之框图 (a) ZC 过程;(b) E 过程;(c) T 过程; (d) F 过程;(e) 函数过程 SYM ;(f) 过程 ADVANCE ⒉ 算法 用递归下降法分析上述算术表达式的框图,如图2-7-5所示。这里,ZC过程为总控程序,主要完成: ⑴ 通知外界键入算术表达式; ⑵ 控制E过程分析算术表达式; ⑶ 根据分析结果之正误,分别通知外界不同的信息。 ZC过程被设计成可以分析无穷多个算术表达式。E、T和F三个过程分别对应〈算术表达式〉、〈项〉和〈因式〉三个产生式的处理。它们用到两个公共过程。一个是函数过程SYM,它负责从输入字符串ST中取出下一个字符,并存入SYM中等待分析。另一个过程ADVANCE负责剔除ST中的首字符。 算法的书写和实现也请参考课堂教学所给出的方法和实例,不一定照搬以上的框图。 ⒋ 小结 ⑴ 实习前的准备 按实习目的和要求,用PASCAL语言编写一个语法分析程序,同时考虑相应的数据结构。 ⑵ 调试 调试例子应包括符合语法规则的算术表达式,以及分析程序能够判别的若干错例。 ⑶ 输出 对于所输入的算术表达式,不论对错,都应有明确的信息告诉外界。 ⑷编写上机实习报告。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值