📄 4.10.3.htm
字号:
<html>
<head>
<title>4.3的解答</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<link type="text/css" rel="stylesheet" href="../css/specification.css">
</head>
<body background="../images/background2.gif">
<center>
<center><font class="title2"><b>练习4.3</b></font></center><br>
</center>
<table><tr><td> </td>
<td class="content">
解:<br>
①消除给定文法中的左递归,并提取公因子:<br>
bexpr→bterm {or bterm }<br>
bterm→bfactor {and bfactor} <br>
bfactor→not bfactor | (bexpr) | true |false <br>
② 用类Pascal语言写出其递归预测分析器<br>
PROCEDURE bexpr;<br>
BEGIN<br>
bterm<br>
WHILE (lookahead =='or')<br>
BEGIN<br>
match ('or');<br>
bterm;<br>
END;<br>
END;<br>
<br>
PROCEDURE bterm;<br>
BEGIN<br>
bfactor;<br>
WHILE (lookahead =='and');<br>
BEGIN<br>
match ('and');<br>
bfactor;<br>
END;<br>
END;<br>
<br>
PROCEDURE bfactor;<br>
BEGIN<br>
if (llokahead=='not')<br>
then BEGIN<br>
match ('not');<br>
bfactor;<br>
END<br>
else if (lookahead=='(')<br>
then BEGIN<br>
match ('(');<br>
bexpr;<br>
match(')');<br>
END<br>
else if (lookahead =='true')<br>
then match ('true)<br>
else if (lookahead=='false')<br>
then match ('false');<br>
else error;<br>
END;<br>
</td></tr></table>
</body>
</html>
<html><script language="JavaScript">
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -