⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 9.7.7.2.htm.bak

📁 建立《编译原理网络课程》的目的不仅使学生掌握构造编译程序的原理和技术
💻 BAK
字号:
<html>

<head>
<title>编译原理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<link type="text/css" rel="stylesheet" href="../css/specification.css">
</head>

<BODY>

<table align=right width=300>
<tr>
<td><img src="../images/previous.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='9.7.7.1c.htm'" ></td>
<td>
<img src="../images/next.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='9.7.7.3.htm'" ></img></td>
</tr>
</table>
<br><br>

<font class="title2"><b>9.7.7.2 强度削弱用于归纳变量的算法</b></font>            


<table>
<tr>
<td>&nbsp&nbsp&nbsp&nbsp</td>
<td class="content">
<br>
<font class = "definition">算法9.12 强度削弱用于归纳变量 </font><br>
    输入:循环L,附带到达_定值信息和算法9.11(寻找归纳变量)计算的<br>
&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp归纳变量族。 <br>
    输出:强度削弱用于归纳变量后的循环。 <br>
    方法:依次对循环的每个基本归纳变量i执行:<br>
&nbsp&nbsp &nbsp&nbsp;  对i族的每个三元组为(i,c,d)的一般归纳变量j执行: <br>
 &nbsp&nbsp&nbsp&nbsp  (1) 建新变量s,但如果变量j1和j2有同样的三元组,则仅建一个<br>
&nbsp&nbsp&nbsp&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp;新变量用于两者; <br>
 &nbsp&nbsp&nbsp&nbsp  (2) 用j:=s代替j 的赋值; <br>
 &nbsp&nbsp&nbsp&nbsp  (3) 在L中紧接在赋值语句i:=i+n的后面(n是常量)加上: <br>&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp &nbsp;&nbsp;            s:=s+r <br>
&nbsp&nbsp&nbsp&nbsp;&nbsp;&nbsp&nbsp;&nbsp; 	其中r=c*n,因为c和n是常量,所以c*n被计算为一个常量。把s<br>
&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp;&nbsp;放入i族,三元组为(i,c,d)。 <br>
&nbsp&nbsp&nbsp&nbsp  (4) 还必须保证在循环的入口处s的初值为c*i+d,这个初始化工作<br>
&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp;&nbsp;把下面<br>
&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp     s:=c*i &nbsp&nbsp/*如果c为1,则s:=i*/ <br>
&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp     s:=s+d &nbsp&nbsp /*如果d为0,则省略*/ <br>
&nbsp&nbsp&nbsp&nbsp&nbsp &nbsp;&nbsp;  的赋值放在前置块的末尾。<br>
 注意: s是i族的归纳变量。 </p>
</td>
</tr>
</table>

<p>
<table>
<tr>
<td><font class="yanshi">&nbsp &nbsp观看演示&nbsp</font></td>
<td><font color=blue onmouseover="javascript:style.cursor='hand'" onclick="javascript:open('applet/9772/Page1.htm','_blank','menu=no,toolbar=no,location=no,directories=no,status=no,scrollbars=yes,resizable=yes,copyhistory=no,left=100,top=100,width=800,height=600')">寻找归纳变量、强度削弱</font></td>
<td><img src="../images/yanshi.gif"></img></td>
</tr>
</table>
<hr size=2 width=90% align=center color=red><br>
</p>

<table>
<tr>
<td>&nbsp&nbsp&nbsp&nbsp</td>
<td class="content">
<p align=center><img src="images/9_40.gif"> </p>
<p>	<font class = "example">例9.35</font> 如果从里向外考虑图9.45(a)的循环。因为内循环B2和B3的处理非常类似,所以仅讨论B3的循环。在例9.34中,已求出j是它的基本归纳变量,t4是它的另一个归纳变量,三元组为(j,4,0)。使用算法9.12的(1),构造新变量s4。根据(2),用t4:=s4代替赋值语句t4:=4*j。在步骤(3),赋值s4:=s4-4插在赋值j:=j-1的后面。设置B2'为循环的前置块,根据(4)把s4的置初值的指令s4:=4*j放在B2'中。 <br>
<p>    在上例中,我们没有考虑外循环(B2→B3→B4→B5),当考虑外循环时,流图如图9.45(b),这里有四个变量 i,S2,j和S4都为归纳变量。算法9.11的步骤(3)已把新建变量分别加入了i族和j族。为了完成i和j的删除,使用归纳变量删除算法。 <br>
<p>    强度削弱后我们会发现有些归纳变量仅用于测试,可以用某个归纳变量的测试代替该归纳变量的测试。例如,若i和t是归纳变量,t的值总是i的4倍,那么测试i>=j等价于t>=4*j,替换后有可能删除归纳变量i。如果t= -4*i,那么需要同时改变关系算符,因为i>=j等价于t<= -4*j。在下面的算法,考虑乘数是正的情况。算法也能推广到适用于负数的情况。<br>
</td>
</tr>
</table>

<br>
<table align=right width=300>
<tr>
<td>
<img src="../images/previous.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='9.7.7.1c.htm'" ></img></td>
<td><img src="../images/next.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='9.7.7.3.htm'" ></td>
</tr>
</table>

</BODY>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -