c++ - 二叉搜索树插入数据问题

标签 c++ binary-search-tree

我正在尝试实现我自己的二叉搜索树,我一直坚持插入数据,你能解释一下我做错了什么吗。

void tree::add(int data) {
    tree * tmp = new tree;

    if (root == NULL) {
        root = tmp;
        root->data = data;
        root->left = NULL;
        root->right = NULL;
    }
    else if (data <= root->data) {  
        left = tmp;
        left->data = data;
        left->left = NULL;
        left->right = NULL;

        while (tmp != NULL) {
            if (data <= left->data) {
                tmp = left->left;
            } else {
                tmp = left->right;
            }

        }
}

我正在尝试填充左节点,如果我的数据小于根,但如果数据大于此叶子但仍小于根,则它应该是右子节点,但实际上我有访问权限

最佳答案

您应该修改算法的逻辑:

//here you set the pointers to null 
left->left = NULL;
left->right = NULL;

while (tmp != NULL) {
    if (data <= left->data) {
        // here at the first time 
        tmp = left->left;
    } else {
        // or here 
        tmp = left->right;
    }
    // tmp will be set to null and the exection will end immediately
}

关于c++ - 二叉搜索树插入数据问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55589040/

相关文章:

c++ - 如何解决此 TabStop 样式问题

c++ - 具有依赖关系的共享库的动态链接

c++ - 使用模板C++重载运算符

C++ "placement new"错综复杂

c++ - Boost.flyweight 和 Boost.MPL

c - 如何按名称(字符串)搜索和排序 BST?按队列打印并缩进?

algorithm - 给定一个 preOrder 和 inOrder 序列,可能有多少级阶 BST 序列?

c - 如何在不释放内容的情况下释放指针?辅助变量

database - 用于搜索属性的数据库表的优化设计

python - 在递归查找最大路径和时,追加二叉树的左或右方向