求二叉树结点值与对应的层次
W1nds 2011-11-19 05:09:58 先序遍历二叉树
输出其结点值与对应的层次
#include<iostream>
using namespace std;
struct bnode{
char data;
struct bnode *lchild, *rchild;
};
class BiTree
{
public:
BiTree();
int n;
void preorder(){preorder(root);};
void creat(){creat(root);};
private:
bnode *root;
void preorder(bnode *T);
void creat(bnode * &T);
};
BiTree::BiTree()
{
n=0;
root=NULL;
}
void BiTree::creat(bnode * &T)
{
char x;
cin>>x;
if(x=='.') T=NULL;
else
{
T=new bnode;
T->data=x;
creat(T->lchild);
creat(T->rchild);
}
}
void BiTree::preorder(bnode *T)
{
if(T!=NULL) n++;
cout<<"结点:"<<T->data;
cout<<"层次:"<<n<<endl;
preorder(T->lchild);
preorder(T->rchild);
n--;
}
int main()
{
BiTree A;
A.creat();
A.preorder();
return 0;
}
感觉没问题啊
就是没有delete动态申请的节点
输出几个之后会崩溃掉,没有输出完
求指教