【数据结构】 二叉树的实现

学习数据结构基础,如有错误,请指正。



/************************************************************************
   数据结构:二叉树的实现,创建、先序、中序、后序遍历(递归实现)                                                               
************************************************************************/

#ifndef __BITTREE_H__
#define __BITTREE_H__

typedef char ElemType;

struct BitNode{
	ElemType data;
	BitNode *lChild;
	BitNode *rChild;
};

class BitTree{
public:
	BitTree();
	~BitTree();
	
	void creatBitTree(BitNode* &tree);
	void preOrderTraverseTree(BitNode* tree);
	void inorderTraverseTree(BitNode* tree);
	void posOrderTraverseTree(BitNode* tree);
	void visit(ElemType e);

	BitNode *bitTree;
};


#endif // __BITTREE_H__



#include "BitTree.h"
#include <iostream>
using std::cout;
using std::cin;
using std::endl;

BitTree::BitTree()
{
	this->bitTree = NULL;
}
BitTree::~BitTree()
{

}

void BitTree::creatBitTree(BitNode* &tree)
{
	// 先序、递归建树
	cout<<"enter a node char:";
	char ch = NULL;
	cin>>ch;
	if ( 'q' == ch )
	{
		tree = NULL;
	}
	else{
		tree = new BitNode();
		tree->data = ch;

		this->creatBitTree( tree->lChild );
		this->creatBitTree( tree->rChild );
	}
}
void BitTree::preOrderTraverseTree(BitNode* tree)
{
	if (tree)
	{
		visit(tree->data);
		preOrderTraverseTree(tree->lChild);
		preOrderTraverseTree(tree->rChild);
	}
	
}
void BitTree::inorderTraverseTree(BitNode* tree)
{
	if (tree)
	{		
		preOrderTraverseTree(tree->lChild);
		visit(tree->data);
		preOrderTraverseTree(tree->rChild);
	}
}
void BitTree::posOrderTraverseTree(BitNode* tree)
{
	if (tree)
	{
		preOrderTraverseTree(tree->lChild);
		preOrderTraverseTree(tree->rChild);
		visit(tree->data);
	}
}
void BitTree::visit(ElemType e)
{
	cout<<e;
}

int main()
{
	BitTree *aTree = new BitTree();
	aTree->creatBitTree(aTree->bitTree);

	cout<<"preOrder traverse Tree:"<<endl;
	aTree->preOrderTraverseTree(aTree->bitTree);
	cout<<endl;

	cout<<"inorder traverse Tree:"<<endl;
	aTree->inorderTraverseTree(aTree->bitTree);
	cout<<endl;

	cout<<"posOrder traverse Tree:"<<endl;
	aTree->posOrderTraverseTree(aTree->bitTree);
	cout<<endl;

	getchar();
	return 0;
}

相关文章

【啊哈!算法】算法3:最常用的排序——快速排序       ...
匿名组 这里可能用到几个不同的分组构造。通过括号内围绕的正...
选择排序:从数组的起始位置处开始,把第一个元素与数组中其...
public struct Pqitem { public int priority; ...
在编写正则表达式的时候,经常会向要向正则表达式添加数量型...
来自:http://blog.csdn.net/morewindows/article/details/6...