C++二叉搜索树switch语句问题

C++ Binary search tree switch statement issue

您好,我正在尝试实现二叉搜索树,但我在使用开关 statement.The 时遇到问题 statement.The 值 -1 应该用于访问菜单并且它可以工作,但同时它被输入在树的顶端。一旦我进入菜单,我输入的任何数字也会在树中结束,下面是代码,它没有给我任何错误,但我无法理解 switch case 语句,任何帮助将不胜感激。

#include <iostream>
#include <cstdlib>
#include <fstream>
#include <iomanip>
#include <stdio.h>

using namespace std;
struct node
{
   int data;
   node *left;
   node *right;
};


void insert(node **tree, int value)
{
   if (*tree == nullptr)
   {
      *tree = new node;
      
      (*tree)->data = value;
      (*tree)->left = nullptr;
      (*tree)->right = nullptr;
   }
   else
   {
      if(value < (*tree)->data)
      {
         // Adding & because (*tree) is a type: node*
         // & references it in the form of a node**
         // Which is what the function expects
         insert( &((*tree)->left) , value);/**/
      }
      else if(value > (*tree)->data)
      {
         insert( &((*tree)->right) , value);
      } 
      else
      {
         return;
      }
   }
}



void inorder(node *tree)
{
   if (tree != nullptr)
   {
      inorder(tree->left);
      cout << tree->data << ", ";
      inorder(tree->right);
   }
}

void preOrder(node *tree)
{
   if (tree != nullptr)
   {
      cout << tree->data << ", ";
      preOrder(tree->left);
      preOrder(tree->right);
   }
}

void postOrder(node *tree)
{
   if (tree != nullptr)
   {
      postOrder(tree->left);
      postOrder(tree->right);
      cout << tree->data << ", ";
   }
}

void delete_tree(node *tree)
{
   if(tree != NULL)
  {
    delete_tree(tree->left);
    delete_tree(tree->right);
    delete tree;
    cout << "value deleted: " << tree->data << endl;
  }   
}

int main(int argc, char **argv)
{
   node *tree = nullptr;


   while (true)
   {
      int num;
     
      cout << "\n\nEnter a value into the tree(type -1 for options)\n";
      cin >> num;
      insert(&tree, num);

      while(num == -1)
      {
         cout<<endl<<endl;
         cout<<" Binary Search Tree Operations "<<endl;
         cout<<" ----------------------------- "<<endl;
         cout<<" 0. Print in order "<<endl;
         cout<<" 1. Pre-Order Traversal "<<endl;
         cout<<" 2. Post-Order Traversal "<<endl;
         cout<<" 3. Insert number "<<endl;
         cout<<" 4. Delete tree "<<endl;
         cout<<" Enter your choice : ";
         cin>>num;
      }
      switch(num)
      {
         case 0 : 
            cout<<endl;
            cout<<" Printing in Order "<<endl;
            cout<<" -------------------"<<endl;
            inorder(tree);
         break;
         
         case 1 : 
            cout<<" Pre-Order Traversal "<<endl;
            cout<<" -------------------"<<endl;
            preOrder(tree);
         break;
         
         case 2 : 
            cout<<" Post-Order Traversal "<<endl;
            cout<<" -------------------"<<endl;
            postOrder(tree);
         break;

         case 3 : 
            cout<<" Insert number into the tree "<<endl;
            cout<<" -------------------"<<endl;
            insert(&tree, num);
         break;

         case 4 : 
            cout<<" delete the tree "<<endl;
            cout<<" -------------------"<<endl;
            delete_tree(tree);
         break;
      }
   }
   return 0;
}

之后你有 insert(&tree, num);
cout << "\n\nEnter a value into the tree(type -1 for options)\n";
cin >> num;

所以你总是会添加一个数字,即使它是-1。您需要在调用插入之前检查 -1。