二叉排序树平均检索长度(ASL)的算法

对于二叉排序树的ASL算法

二叉排序树的特点是左孩子小于根节点,右孩子大于根节点
之前寻找博客上计算ASL的算法时,看到用的是设置一个max值来判断是否换层,遍历二叉排序树,若是大于max则是属于同一层,赋值给max,直到找到小于max的节点就是下一层,但是对于如果一层中只有最后一个节点(即这一层最大的节点)有右孩子,max值就一直是增加的,则不会换层
解决方法
使用一个父节点数组和队列,有孩子节点则加入父节点队列,存储每一层的父节点数,一层结束后输出前面的父节点,只留下该层最后一父节点,则可以判断一层结束;
若节点队列为空且当前节点无孩子,则整个二叉排序树结束。
代码片

typedef struct BTreeNode
{
   
int data;
struct BTreeNode *leftchild;
struct BTreeNode *rightchild;
}BinTreeNode;

代码片

void  BSTS_ASL(BinTree bt)//平均查找长度ASL
{
   
 queue<BinTree> a;
 queue<BinTree> parent;
 BinTree p;
 int n = 0; //个数
 int w[10] = {
    0 };
 int fu[10] = {
    0 };
 int i = 1, flag = 1;
 double r;
 if (bt == NULL)
  return 0;//节点为空
 p = bt;
 a.push
  • 2
    点赞
  • 69
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值