我们也可以用递归实现
但递归的最坏情况可能需要有h个函数调用栈帧,或者说h个函数同时执行
但循环的实现一直都是一个函数在执行
先查找找到插入的位置,然后mallloc一个新的空间,如果遇到与插入值一样的元素,则插入失败
函数参数是引用类型从而能够修改其值
首先T是空,会创造一个节点,其值和插入的值一样,这样就开始形成一颗树,接着插入过程和之前一样
不同序列对应的二叉排序树不一定相同,也不一定不同
直接删之后依然可以保存二叉树的特性
直接替代即可,此时依然满足,替换后,子树相对于父父树一定满足父树的相对于其父父树的性质
此时可以找到右子树的最小节点来替换(右子树的最左下节点)
此时可以找到左子树的最大节点来替换(左子树的最右下节点)
最坏的查找长度也是和这颗数的高度一样
如果使得二叉树的尽可能地平衡,那么二叉树的高度会越低
查找失败时为落在空结点的位置,先补齐空结点