首页 > 其他 > 详细

&12-2 查找二叉搜索树

时间:2016-07-29 17:12:13      阅读:111      评论:0      收藏:0      [点我收藏+]

#1,定理

在一棵高度为h的二叉搜索树上,动态集合上的操作SEARCH、MINIMUM、MAXIMUM、SUCCESSOR和PREDECESSOR可以在O(h)时间内完成。

 

#2,伪代码

分别是搜索,迭代形式的搜索,取最小值,取最大值,找后继,找前驱。

技术分享
1 //x is an element of the tree, k is the key of element we want to search.
2 TREE-SEARCH(x,k)
3 if x==NULL or k==x.key
4     return x;
5 
6 if k<x.key
7     return TREE-SEARCH(x.left,k);
8 else
9     return TREE_SEARCH(x.right,k);
TREE-SEARCH
技术分享
1 ITERATIVE_TREE_SEARCH(x,k)
2 while x!=NULL and k!=x.key
3     if k<x.key
4         x=x.left;
5     else
6         x=x.right;
7 return x;
ITERATIVE_TREE_SEARCH
技术分享
1 TREE-MINIMUM(x)
2 while x.left!=NULL
3     x=x.left;
4 return x;
TREE-MINIMUM
技术分享
1 TREE-MAXIMUM(x)
2 while x.right!=NULL
3     x=x.right;
4 return x;
TREE-MAXIMUM
技术分享
1 TREE-SUCCESSOR(x)
2 if x.right!=NULL
3     return TREE_MINIMUM(x.right);
4 y=x.p;
5 while y!=NULL and x==y.right
6     x=y;
7     y=y.p;
8 return y;
TREE-SUCCESSOR
技术分享
1 TERR-PREDECESSOR(x)
2 if x.left!=NULL
3     return MAXIMUM(x.left);
4 y=x.p;
5 while y!=NULL and x==y.right
6     x=y;
7     y=y.p;
8 return y;
TERR-PREDECESSOR

 

&12-2 查找二叉搜索树

原文:http://www.cnblogs.com/sophia-hxw/p/5718909.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!