二叉树
在计算机科学中,二叉树是每个结点最多有两个子树的树结构。通常子树被称作“左子树”(left subtree)和“右子树”(right subtree)。二叉树常被用于实现二叉查找树和二叉堆。
一棵深度为k,且有2^k-1个节点的二叉树,称为满二叉树。这种树的特点是每一层上的节点数都是最大节点数。而在一棵二叉树中,除最后一层外,若其余层都是满的,并且最后一层或者是满的,或者是在右边缺少连续若干节点,则此二叉树为完全二叉树。具有n个节点的完全二叉树的深度为floor(log2n)+1。深度为k的完全二叉树,至少有2k-1个叶子节点,至多有2k-1个节点。。
- 以上是书面解答 —— 下面我总结一下
结构
- 二叉树分为 : 根节点 —— 中间节点 ——叶子节点
- 根节点是没有子节点的
- 中间节点有子节点也有父节点
- 叶子节点只有父节点没有子节点
执行方式
- 小于父节点的节点放在左边 大于的放在右边 以此类推 不断的递归
function BinaryTree () {
//创建对象
class Node {
constructor (key) {
this.key = key
this.left = null
this.right = null
}
}
//初始化root
let root = null
const insertNode = (node, newNode) => {
if (newNode.key < node.key) {
if (node.left === null) {
node.left = newNode
} else {
insertNode(node.left, newNode)
}
} else {
if (node.right === null) {