很久没有接触二叉树了,写这个当作练手,接下来会比较详细地实现二叉树的各个功能及应用。

/*
* BinaryTree.cpp
* Author: Qiang Xiao
* Time: 2015-07-17
*/ #include<iostream>
#include<string>
using namespace std; template<class ElemType>
class BinaryNode{
public:
ElemType data;
BinaryNode<ElemType>* leftChild;
BinaryNode<ElemType>* rightChild; BinaryNode();
BinaryNode(const ElemType elem, BinaryNode<ElemType>* left = NULL, BinaryNode<ElemType>* right = NULL);
void print() const;
}; template<class ElemType>
void BinaryNode<ElemType>::print() const{
cout << this->data << endl;
} template<class ElemType>
BinaryNode<ElemType>::BinaryNode(){
this->leftChild = NULL;
this->rightChild = NULL;
} template<class ElemType>
BinaryNode<ElemType>::BinaryNode(const ElemType elem, BinaryNode<ElemType>* left, BinaryNode<ElemType>* right){
this->data = elem;
this->leftChild = left;
this->rightChild = right;
} /**************************************************************************************************/
template<class ElemType>
class BinaryTree{
private:
BinaryNode<ElemType>* root;
public:
BinaryTree();
BinaryTree(BinaryNode<ElemType>* r);
// ~BinaryTree();
BinaryNode<ElemType>* getRoot() const;
bool isEmpty() const;
void preOrder(BinaryNode<ElemType>* r) const;
void inOrder(BinaryNode<ElemType>* r) const;
void postOrder(BinaryNode<ElemType>* r) const;
}; template<class ElemType>
BinaryTree<ElemType>::BinaryTree(BinaryNode<ElemType>* r){
root= r;
} template<class ElemType>
BinaryTree<ElemType>::BinaryTree(){
root= new BinaryNode<ElemType>();
} template<class ElemType>
BinaryNode<ElemType>* BinaryTree<ElemType>::getRoot() const{
return root;
} template<class ElemType>
bool BinaryTree<ElemType>::isEmpty() const{
return root== false;
} template<class ElemType>
void BinaryTree<ElemType>::preOrder(BinaryNode<ElemType>* r) const{
if(r== NULL)
return;
cout<<r->data<<"\t";
preOrder(r->leftChild);
preOrder(r->rightChild);
} template<class ElemType>
void BinaryTree<ElemType>::inOrder(BinaryNode<ElemType>* r) const{
if(r== NULL)
return;
inOrder(r->leftChild);
cout<<r->data<<"\t";
inOrder(r->rightChild);
} template<class ElemType>
void BinaryTree<ElemType>::postOrder(BinaryNode<ElemType>* r) const{
if(r== NULL)
return;
postOrder(r->leftChild);
postOrder(r->rightChild);
cout<<r->data<<"\t";
} int main(){
BinaryNode<string>* right1= new BinaryNode<string>("RIGHT1");
BinaryNode<string>* left= new BinaryNode<string>("LEFT", NULL, right1);
BinaryNode<string>* right= new BinaryNode<string>("RIGHT");
BinaryNode<string>* root = new BinaryNode<string>("ROOT", left, right); BinaryTree<string>* tree= new BinaryTree<string>(root);
cout<<"preOrder: \t";
tree->preOrder(root);
cout<<"\ninOrder: \t";
tree->inOrder(root);
cout<<"\npostOrder: \t";
tree->postOrder(root);
cout<<endl; return ;
}

下面是运行结果:

xiaoq@xq-ubun:~/C/DataStructure$ ./BinaryTree.o
preOrder: ROOT LEFT RIGHT1 RIGHT
inOrder: LEFT RIGHT1 ROOT RIGHT
postOrder: RIGHT1 LEFT RIGHT ROOT
xiaoq@xq-ubun:~/C/DataStructure$

这个版本是初级版本,遍历采用递归方式。接下来将不断完善!

欢迎交流!

一个简单二叉树的C++实现(一)的更多相关文章

  1. C 封装一个简单二叉树基库

    引文 今天分享一个喜欢佩服的伟人,应该算人类文明极大突破者.收藏过一张纸币类型如下 那我们继续科普一段关于他的简介 '高斯有些孤傲,但令人惊奇的是,他春风得意地度过了中产阶级的一生,而  没有遭受到冷 ...

  2. C 构造一个 简单配置文件读取库

    前言 最近看到这篇文章, json引擎性能对比报告 http://www.oschina.net/news/61942/cpp-json-compare?utm_source=tuicool 感觉技术 ...

  3. 程序猿修仙之路--数据结构之你是否真的懂数组? c#socket TCP同步网络通信 用lambda表达式树替代反射 ASP.NET MVC如何做一个简单的非法登录拦截

    程序猿修仙之路--数据结构之你是否真的懂数组?   数据结构 但凡IT江湖侠士,算法与数据结构为必修之课.早有前辈已经明确指出:程序=算法+数据结构  .要想在之后的江湖历练中通关,数据结构必不可少. ...

  4. c语言-构建一个静态二叉树

    第一.树的构建 定义树结构 struct BTNode { char data; struct BTNode* pLChild; struct BTNode* pRChild; }; 静态方式创建一个 ...

  5. 哪种缓存效果高?开源一个简单的缓存组件j2cache

    背景 现在的web系统已经越来越多的应用缓存技术,而且缓存技术确实是能实足的增强系统性能的.我在项目中也开始接触一些缓存的需求. 开始简单的就用jvm(java托管内存)来做缓存,这样对于单个应用服务 ...

  6. 在Openfire上弄一个简单的推送系统

    推送系统 说是推送系统有点大,其实就是一个消息广播功能吧.作用其实也就是由服务端接收到消息然后推送到订阅的客户端. 思路 对于推送最关键的是服务端向客户端发送数据,客户端向服务端订阅自己想要的消息.这 ...

  7. ASP.NET Aries 入门开发教程2:配置出一个简单的列表页面

    前言: 朋友们都期待我稳定地工作,但创业公司若要躺下,也非意念可控. 若人生注定了风雨飘摇,那就雨中前行了. 最机开始看聊新的工作机会,欢迎推荐,创业公司也可! 同时,趁着自由时间,抓紧把这系列教程给 ...

  8. 计算机程序的思维逻辑 (60) - 随机读写文件及其应用 - 实现一个简单的KV数据库

    57节介绍了字节流, 58节介绍了字符流,它们都是以流的方式读写文件,流的方式有几个限制: 要么读,要么写,不能同时读和写 不能随机读写,只能从头读到尾,且不能重复读,虽然通过缓冲可以实现部分重读,但 ...

  9. 如何开发一个简单的HTML5 Canvas 小游戏

    原文:How to make a simple HTML5 Canvas game 想要快速上手HTML5 Canvas小游戏开发?下面通过一个例子来进行手把手教学.(如果你怀疑我的资历, A Wiz ...

随机推荐

  1. Ceph相关博客、网站(256篇OpenStack博客)

    官网文档: http://docs.ceph.com/docs/master/cephfs/ http://docs.ceph.com/docs/master/cephfs/createfs/   ( ...

  2. Java实现HTML转PDF的总结

    Java实现HTML转PDF的几种方法—主要解决中文乱码问题 第一:同事在做HTML转PDF中遇到乱码问题 ********************************************** ...

  3. 一个关于Integer的秘密

    先让大家看一段简单的代码: public static voidmain(String[] args) { Integera = 1; Integerb = 1; Integerc = 222; In ...

  4. HDU1506 ( Largest Rectangle in a Histogram ) [dp]

    近期情绪太不稳定了.可能是由于在找实习这个过程碰壁了吧.第一次面试就跪了,可能是我面的是一个新公司,制度不完好,我感觉整个面试过程全然不沾编程,我面试的还是软件开发-后来我同学面试的时候.说是有一道数 ...

  5. redis 缓存技术与memcache的最大差别

    1 什么是redis  redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对很多其它,包含string(字符串).list(链表).set(集合)和zs ...

  6. 1.语言概述-JavaScript权威指南笔记

    上周三的时候交给老板目前的项目第一个迭代回顾会的总结.原本是以综述性的表述方式写的,交给他之后表示程序员不要长篇大论.总结要分为优点缺点期望等等块,每块列出条目,简明扼要的表达出来.这里也用这种风格. ...

  7. VS2015操作Oracle数据需要做那些设置?

    1>在oracle网上下载:ODP.NET 2> 要根据自己的oracle 数据32bit/64bit,选择下载. 3> 根据提示配置tnsnames.ora文件. # alias ...

  8. ASPxGridView-如何在客户端缓存数据

    有时候我们可以直接从后台生成一些值缓存到客户端,在用到的时候无需在进行callback进行取值,减少和服务器的交互.下面的例子缓存列"title_id"和"title&q ...

  9. zoj 1109 zoj 1109 Language of FatMouse(字典树)

    好开心,手动自己按照字典树的思想用c写了一个优化后的trie字典树,就是用链表来代替26个大小的字符数组.完全按照自己按照自己的想法打的,没有参考如何被人的代码.调试了一天,居然最后错在一个小问题上, ...

  10. C语言:类似linux内核的分等级DEBUG宏(打印宏)

    总结几种log打印printf函数的宏定义 http://blog.chinaunix.net/uid-20564848-id-73402.html #include <stdio.h> ...