有人能举例说明二叉树和二叉搜索树的区别吗?
当前回答
二叉树是一种树,其中每个节点最多可以有2个子节点。
二叉搜索树是对它的进一步修改,赋予父结点和两个子结点一定的关系。因为,只有两个子结点,即左子结点和右子结点;关系式定义如下:
左子<=父<=右子
其实就是这么简单。
其他回答
要检查给定的二叉树是否是二叉搜索树,这里有一个替代方法。
按顺序遍历树(即左子->父->右子), 在临时变量中存储遍历的节点数据,比如temp,在存储到temp之前,检查当前节点的数据是否高于前一个。 然后把它打破,树不是二叉搜索树,否则遍历直到结束。
下面是一个Java的例子:
public static boolean isBinarySearchTree(Tree root)
{
if(root==null)
return false;
isBinarySearchTree(root.left);
if(tree.data<temp)
return false;
else
temp=tree.data;
isBinarySearchTree(root.right);
return true;
}
保持室外温度变量
二叉树:每个节点最多有两个叶的树
1
/ \
2 3
二叉搜索树:用于搜索。二叉树,其中左子节点只包含值小于父节点的节点,而右子节点只包含值大于或等于父节点的节点。
2
/ \
1 3
在二叉树中,每个节点有两个子节点:左节点和右节点。 二叉搜索树是一种特殊的树,其中节点被排序,左节点比父节点小,左节点比父节点大。 二叉树允许重复值,二叉搜索树不允许重复值,而且在二叉搜索树中执行任何类型的操作都比在二叉树中更快,因为BST是排序的
二叉树是一种树,其中每个节点最多可以有2个子节点。
二叉搜索树是对它的进一步修改,赋予父结点和两个子结点一定的关系。因为,只有两个子结点,即左子结点和右子结点;关系式定义如下:
左子<=父<=右子
其实就是这么简单。
在二叉搜索树中,所有节点都按照特定的顺序排列——根节点左侧的节点的值小于根节点,节点右侧的所有节点的值大于根节点的值。
推荐文章
- HyperLogLog算法是如何工作的?
- 二叉搜索树的定义中允许重复的键吗?
- 如何有效地清除std::queue ?
- 非递归深度优先搜索算法
- 如何在Java中打印二叉树图?
- 堆与二叉搜索树(BST)
- 多维数组如何在内存中格式化?
- “冰冻词典”是什么?
- 在javascript中从平面数组构建树数组
- 为什么我们使用数组而不是其他数据结构?
- 在Java中从HashMap获取键
- 数组与链表
- set()是如何实现的?
- .Net数据结构:ArrayList, List, HashTable, Dictionary, SortedList, SortedDictionary—速度,内存,以及何时使用每个?
- 为什么std::map被实现为红黑树?