freemandj 2021-03-20 17:34 采纳率: 100%
浏览 41
已采纳

关于二叉排序树,输不出任何结果,C++,求解答Dev

 #include<iostream>
#include<string>
#include<vector>

#include<algorithm>
using namespace std;

class TreeNode
{
public:
    int data;
    TreeNode *left, *right;
    TreeNode() {
    left = right = NULL;
    data=0;
     }
};
class BSTree
{
public:
    TreeNode *root;

    BSTree() { root = NULL; }
    void AddintoTree(int num)
    {
        TreeNode *t = root;
        while (true)
        {
            if (num < t->data)
            {
                if (t->left == NULL)
                {
                    t->left = new TreeNode;
                    t->left->data = num;
                    return;
                }
                else
                {
                    t = t->left;
                }
            }
            else
            {
                if (t->right == NULL)
                {
                    t->right = new TreeNode;
                    t->right->data = num;
                    return;
                }
                else
                {
                    t = t->right;
                }
            }
        }
    }
    void Preorder(TreeNode *root, vector<int> &ans) //递归前序
{
    if (root == NULL)
        return;

    ans.push_back(root->data);
    Preorder(root->left, ans);
    Preorder(root->right, ans);
}
void Inorder(TreeNode *root, vector<int> &ans) //递归中序
{
    if (root == NULL)
        return;

    Inorder(root->left, ans);
    ans.push_back(root->data);
    Inorder(root->right, ans);
}

void Postorder(TreeNode *root, vector<int> &ans) //递归后序
{
    if (root == NULL)
        return;

    Postorder(root->left, ans);
    Postorder(root->right, ans);
    ans.push_back(root->data);
}
TreeNode *search(int value){
    TreeNode *p=root;
    while(p!=NULL||p->data==value){
    if(value<p->data){
        p=p->left;
    }    
    else{
        p=p->right;
    }    
    }
    return p;
}
TreeNode *findmax(){
    TreeNode *p=root;
    while(p!=NULL){
        p=p->left;
    }
    return p;
}

};
int main(){
    BSTree bstree;
    bstree.AddintoTree(1);
     bstree.AddintoTree(2);
          bstree.AddintoTree(9);
               bstree.AddintoTree(7);
                    bstree.AddintoTree(8);
                         bstree.AddintoTree(4);
                   
    vector<int> ans;
    bstree.Inorder(bstree.root,ans);
    vector<int>:: iterator it;
    for(it=ans.begin();it!=ans.end();it++){
        cout<<*it;
    }
    TreeNode *treenode;
    treenode=bstree.findmax();
    cout<<treenode->data;
    
}

  • 写回答

1条回答 默认 最新

  • cpp_learners 2021-03-20 17:46
    关注

    BSTree类,AddintoTree函数,root都还没分配内存,你就在main函数里进行调用了。此时root为NULL,你还使用它,就报错了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!