首先查找元素是否在二叉搜索树中,如果不存在,则返回
要删除的结点可能分下面四种情况:
a. 要删除的结点无孩子结点
b. 要删除的结点只有左孩子结点
c. 要删除的结点只有右孩子结点
d. 要删除的结点有左、右孩子结点
看起来有待删除节点有4中情况,实际情况a可以与情况b或者c合并起来,因此真正的删除过程如下:
情况1:删除该结点 且使被删除节点的双亲结点指向被删除节点的左孩子结点--直接删除
情况2:删除该
首先查找元素是否在二叉搜索树中,如果不存在,则返回
要删除的结点可能分下面四种情况:
a. 要删除的结点无孩子结点
b. 要删除的结点只有左孩子结点
c. 要删除的结点只有右孩子结点
d. 要删除的结点有左、右孩子结点
看起来有待删除节点有4中情况,实际情况a可以与情况b或者c合并起来,因此真正的删除过程如下:
情况1:删除该结点 且使被删除节点的双亲结点指向被删除节点的左孩子结点--直接删除
情况2:删除该