PHP

php二叉树如何实现插入操作

小樊
81
2024-10-17 19:30:04
栏目: 编程语言

在PHP中,实现二叉树插入操作首先需要创建一个二叉树类(BinaryTree),然后在该类中实现插入方法(insert)。以下是一个简单的二叉树插入操作实现:

class TreeNode {
    public $value;
    public $left;
    public $right;

    public function __construct($value) {
        $this->value = $value;
        $this->left = null;
        $this->right = null;
    }
}

class BinaryTree {
    public $root;

    public function __construct() {
        $this->root = null;
    }

    public function insert($value) {
        $newNode = new TreeNode($value);
        if ($this->root === null) {
            $this->root = $newNode;
        } else {
            $this->insertNode($this->root, $newNode);
        }
    }

    private function insertNode($node, $newNode) {
        if ($newNode->value < $node->value) {
            if ($node->left === null) {
                $node->left = $newNode;
            } else {
                $this->insertNode($node->left, $newNode);
            }
        } else {
            if ($node->right === null) {
                $node->right = $newNode;
            } else {
                $this->insertNode($node->right, $newNode);
            }
        }
    }
}

// 使用示例
$binaryTree = new BinaryTree();
$binaryTree->insert(50);
$binaryTree->insert(30);
$binaryTree->insert(20);
$binaryTree->insert(40);
$binaryTree->insert(70);
$binaryTree->insert(60);
$binaryTree->insert(80);

在这个例子中,我们首先创建了一个TreeNode类,用于表示二叉树的节点。每个节点包含一个值(value),以及指向左子节点(left)和右子节点(right)的指针。

接下来,我们创建了一个BinaryTree类,用于表示整个二叉树。这个类包含一个指向根节点(root)的指针,以及一个用于插入新节点的insert方法。insert方法会创建一个新的TreeNode实例,然后调用insertNode方法将其插入到正确的位置。

insertNode方法是一个递归方法,用于将新节点插入到二叉搜索树中。它首先比较新节点的值与当前节点的值,如果新节点的值较小,则将其插入到当前节点的左子树中;如果新节点的值较大,则将其插入到当前节点的右子树中。这个过程会一直递归进行,直到找到正确的插入位置。

0
看了该问题的人还看了