一个二叉树采用标准存储形式,判定是否满足堆的条件

堆的判定条件为,对于队中的任意子树其根元素和其左右孩子元素之间的关系需要符合堆的定义,例如大顶堆需要保证根结点的值大于等于其左右孩子的值,小顶堆则反之。
算法如下:
1. 指定一个树的根结点,判断根结点与左孩子以及右孩子的关系是否满足堆的要求。
2. 若不满足则返回不是堆
3. 若满足则递归的遍历左子树和右子树重复1的步骤,直到整个树被遍历完成。
例如判断大顶堆,实现如下:
1. 调用方法heapJudge(&root); //参数为二叉树的根节点
2. heapJudge方法实现如下
bool heapJudge(TreeNode *root)
{
bool bReturnLeft = false;
bool bReturnRight = false;
if (root == null) //为空返回true,说明到此为止依然是符合堆的条件的
{
return true;
}
//左节点的数据大于根结点数据说明不是大顶堆返回false
if ((root->left != null) && (root->data < root->left->data))
{
return false;
}
//右节点的数据大于根结点数据说明不是大顶堆返回false
if ((root->right != null) && (root->data < root->right->data))
{
return false;
}
//遍历左子树
bReturnLeft = heapJudge(root->left);
//遍历右子树
bReturnRight = heapJudge(root->right);
//返回两个子树的结果,其中有一个不符合则说明不是堆
return (bReturnLeft&&bReturnRight);
}

转载于:https://my.oschina.net/betayuan/blog/1543883

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值