2019.4.27二叉树

#include "pch.h"

#include

using namespace std;
typedef struct tree {
int data;
struct tree *left;
struct tree *right;
}TREE,*Tree;
void CreateTree(TREE &T);
void PreOrder(TREE &T);
void InOrder(TREE &T);
void PostOrder(TREE &T);
int main()
{
Tree T;
CreateTree(T);
cout << "前序" << endl;
PreOrder(T);
cout << "中序" << endl;
InOrder(T);
cout << "后序" << endl;
PostOrder(T);
return 0;
}
void CreateTree(TREE &T)
{
int data;
cin >> data;
if (data == -1) {
T = NULL;
return;
}
T = new TREE;
T->data = data;
CreateTree(T->left);
CreateTree(T->right);
}
void PreOrder(TREE &T)//先序遍历
{
if (T)
{
cout << T->data << " ";
PreOrder(T->left);
PreOrder(T->right);
}
}
void InOrder(TREE &T)//中序遍历
{
if (T) {
InOrder(T->left);
cout << T->data;
InOrder(T->right);
}
}
void PostOrder(TREE &T)//后序遍历
{
PostOrder(T->left);
PostOrder(T->right);
cout << T->data << " ";
}

存在问题,跑不起来= =

你可能感兴趣的:(2019.4.27二叉树)