- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第6章 二叉树 二叉排序树 用(ai+1,ai+2,…,aj)作为内部结点构造最佳二叉排序树T[i,j]的方法可如下进行:分别用ai+1,ai+2,…,aj为根,共考虑j-i棵二叉排序树,以ak为根的二叉排序树其左子树包括ai+1,…,ak-1,而包括这些关键码为内部结点的最佳二叉排序树T[i,k-1]已在前面的步骤确定,C[i,k-1]已求出,而以ak为根的二叉排序树其右子树包括ak+1,ak+2,…,aj,以这些关键码为内部结点的最佳二叉排序树T[k,j]也已在前面的步骤确定,C[k,j]已求出。对于ik?j,找出使C[i,k-1]+C[k,j]最小的那个k’,以ak’为根,T[i,k’-1]为左子树,T[k’,j]为右子树的那棵二叉排序树就是所求的T[i,j]。其花费C[i,j]等于其根的左子树花费C[i,k’-1]加上右子树花费C[k’,j],再加上结点总的权W[i,j],即C[i,j]=W[i,j]+ C[i,k’-1]+ C[k’,j]。 佑姻霉碧菠息奖梁饺蝉肃匈谤惨瞪睁蜡停妒刹镑酉篷赘寝渺硅镜秃杂费驾binary Treebinary Tree 综上所述,T[i,j]是最优查找树必须满足条件: C[i,j]=W[i,j]+ (C[i,k-1]+C[k,j]) (9-20) 假设n=4,且(a1,a2,a3,a4)=(10,18,26,50);(p1,p2,p3,p4)=(1,4,3,2),(q0,q1,q2,q3,q4)=(1,2,3,3,1),试构造出有序序列a1,a2,a3,a4所组成的最优查找树。 例 首先根据式(9-20)构造包括一个内部结点的最佳二叉排序树,其花费的代价分别是C[0,1]=4,C[1,2]=9,C[2,3]=9和C[3,4]=6,如图9.12(a)所示。 丑缺疗傣象娱暇伯朱障窄宿弦霍农淄裙窟闺巡抛懊迂寥哥破琼帖跟旷炊俱binary Treebinary Tree 2、 二叉树中序遍历的非递归实现 中序遍历一棵非空树t时 ,首先应该进入t的左子树访问,此时由于t的根结点及右子树尚未访问,因此必须将t保存起来,放入栈中,以便访问完其左子树后,从栈中取出t,进行其根结点及右子树的访问;对t的左子树和右子树的遍历也是如此。在整个二叉树中序遍历的过程中,程序要做的工作始终分成两个部分:当前正在处理的树(子树)和保存在栈中待处理的部分,只有这两部分的工作均完成后,程序方能结束。 婴歼祭鹰卷篮兼柑吁镁树傍呢搜痘挺子拓肃评恐潜厕恃娠贩阎他蹦朵陕缨binary Treebinary Tree void inorder1(bintree t) { seqstack s; s.top=-1; while((t!=NULL) || (s.top!=-1)) { while (t) { push(s,t); t=t-lchild; } if (s.top!=-1) { t=pop(s); printf(%c ,t-data); t=t-rchild; } } } 趁荤佰洗桨元碱荫员涌诚溉议平娘摔艘淬绝蘑颤舆少沙慕刑谜肿雕佣餐诵binary Treebinary Tree 3 、二叉树后序遍历的非递归实现 后序遍历一棵非空树t时,首先应该进入t的左子树访问,此时由于t的右子树及根结点尚未访问,因此必须将t保存在栈中,以便访问完其左子树后,从栈中取出t,进行其右子树及根结点的访问。值得注意的是,当一个元素位于栈顶即将被处理时,其左子树的访问一定已经完成,如果其右子树尚未遍历,接下来应该进入其右子树的访问,而此时该栈顶元素是不能出栈的,因为其根结点还未被访问;只有等到其右子树也访问完成后,该栈顶元素才能出栈,并输出其根结点的值。因此一个元素位于栈顶时,必须设法识别其右子树是否已被访问。 皿离童摸蜀含日魏得系钡骗蒲菩焙肿慌烽否旅许羡获渍弛粹送霉蓟勾驱掌binary Treebinary Tree 解决的方法为:使用seqstack类型中的数组tag, 用于标识栈中每个元素的状态: ? 每个元素刚进栈时,其tag值初始化为0; ? 当某一元素位于栈顶即将被处理时: (1)如果其tag值为0,意味着其右子树尚未访问,
文档评论(0)