加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

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

发布时间:2020-12-15 06:33:26 所属栏目:安全 来源:网络整理
导读:学习数据结构基础,如有错误,请指正。 /************************************************************************ 数据结构:二叉树的实现,创建、先序、中序、后序遍历(递归实现) *****************************************************************

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



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

#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;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读