MarkAllenWeiss的《数据结构与算法分析》第4章中讲到二叉查找树这种数据结构,关于删除的代码是这样的://删除以t为根的BST中值为x的节点voidremove(intx,BinaryNode*&t){if(t==NULL){return;}if(xdata) {remove(x,t->left);}elseif(x>t->data){remove(x,t->right);}//左右都有节点的情况elseif(t->left!=NULL&&t->right!=NULL){t->data=findMin(t->right)->data;//右子树最小的节点remove(t->data,t->right);}else{BinaryNode*oldNode=t;t=(t->left!=NULL)?t->left:t->right);deleteoldNode;}}二叉树的基本性质是节点大于其左子树的所有节点,小于其右子树的所有节点,在这个删除算法中,当删除的节点有2个儿子的情况的时候,为什么是从右子树找出最小的节点而不是从左子树找出最大的节点呢?
明月笑刀无情
Smart猫小萌
相关分类