思路:若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
它的左、右子树也分别为二叉排序树。
递归遍历就可以了,反正就是左孩子的key比根节点的key小,右孩子的key比根节点的key大,一旦有不满足条件的就判定不是。
完整的代码如下:
本文介绍了如何判断一个给定的二叉树是否为二叉排序树。通过递归遍历二叉树,检查每个节点的左右子树是否满足二叉排序树的条件:左子树所有节点小于根节点,右子树所有节点大于根节点。提供了一个C语言的代码示例来实现这个功能。
思路:若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
它的左、右子树也分别为二叉排序树。
递归遍历就可以了,反正就是左孩子的key比根节点的key小,右孩子的key比根节点的key大,一旦有不满足条件的就判定不是。
完整的代码如下:
1467