📄 6_17.htm
字号:
<HTML>
<HEAD>
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=gb_2312-80">
<META NAME="Generator" CONTENT="Microsoft Word 97">
<TITLE>第 2 章 线性表</TITLE>
</HEAD>
<BODY>
<B><FONT SIZE=3><P ALIGN="JUSTIFY">17. </FONT><FONT FACE="宋体" LANG="ZH-CN" SIZE=3>例</FONT><FONT SIZE=3> 6-4 </B></FONT><FONT FACE="宋体" LANG="ZH-CN" SIZE=3>编写算法。已知二叉树的前序遍历和中序遍历序列,构造对应的二叉树。</P>
<P ALIGN="JUSTIFY">	</FONT><FONT SIZE=3>BiTNode *Restore ( <B>char</B> *pstr, <B>char</B> *istr, <B>int</B> n ) </FONT><B><FONT FACE="宋体" LANG="ZH-CN" SIZE=3>{</P>
</B><P ALIGN="JUSTIFY">	</FONT><FONT SIZE=3>// </FONT><FONT FACE="宋体" LANG="ZH-CN" SIZE=3>由二叉树的前序遍历和中序遍历序列,构造对应的二叉树</P>
<B><P ALIGN="JUSTIFY">	</FONT><FONT SIZE=3> if</B> ( n <= 0 ) <B>return</B> NULL;</P>
<P ALIGN="JUSTIFY">	 ptr = ( BiTNode *) <B>malloc</B> ( <B>sizeof</B> ( BiTNode ) );</P>
<P ALIGN="JUSTIFY">	 ptr->data = *pstr;</P>
</FONT><B><FONT FACE="宋体" LANG="ZH-CN" SIZE=3><P ALIGN="JUSTIFY">	</FONT><FONT SIZE=3> for </B>( rstr = istr; rstr < istr+n; rstr++ )</P>
</FONT><B><FONT FACE="宋体" LANG="ZH-CN" SIZE=3><P ALIGN="JUSTIFY">		</FONT><FONT SIZE=3>if </B>( *rstr = = *pstr ) <B>break</B>;					// </FONT><FONT FACE="宋体" LANG="ZH-CN" SIZE=3>在中序遍历序列中找根结点</P>
<P ALIGN="JUSTIFY">	</FONT><FONT SIZE=3> k = rst - istr;									// </FONT><FONT FACE="宋体" LANG="ZH-CN" SIZE=3>左子树的结点数</P>
<P ALIGN="JUSTIFY">	</FONT><FONT SIZE=3> ptr->lchild = Restore ( pstr+1, istr, k );</P>
<P ALIGN="JUSTIFY">	 ptr->rchild = Restore ( pstr+k+l, rstr+1, n-k-l );</P>
</FONT><B><FONT FACE="宋体" LANG="ZH-CN" SIZE=3><P ALIGN="JUSTIFY">	</FONT><FONT SIZE=3> return</B> ptr;</P>
</FONT><B><FONT FACE="宋体" LANG="ZH-CN" SIZE=3><P ALIGN="JUSTIFY">	}</FONT><FONT SIZE=3> </B>// Restore</P></FONT></BODY>
</HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -