//Header.h

#ifndef _HEAD_
#define _HEAD_ #include <queue>
#include <iostream>
using namespace std; typedef char TElemType;
typedef int Status;
#define OK 0
#define ERROR -2
#define OverFlow -1 //普通二叉树
typedef struct BiTNode
{
TElemType data;
struct BiTNode *lchild, *rchild;
} BiTNode, *BiTree; //线索二叉树
typedef enum {Link, Thread} PointerTag; typedef struct BiThrNode
{
TElemType data;
struct BiThrNode *lchild, *rchild;
PointerTag LTag, RTag;
} BiThrNode, *BiThrTree; //仅为普通二叉树
void CreateBiTree(BiTree &T);
void PreOrderTraverse(BiTree T);
void LevelTraverse(BiTree T); //线索二叉树
void CreateBiThrTree(BiThrTree &T);
Status InOrderThread_Head(BiThrTree &head, BiThrTree &T);
Status InOrderTraverse_Thr(BiThrTree T); #endif

//Functions.cpp

#include "Header.h"

//因为BiTree是一个结构体,所以这里必须用“引用&”,否则将会新建一个空的BiTree,导致在创建二叉树时,创建失败(我们指定的BiTree为空);
//进而导致后面的遍历直接退出(因为传进去的BiTree不管是否为“引用&”都为空);
//另外只要创建的树正确,那么在遍历的时候不论是否“引用&”都可以得到正确的遍历顺序 //创建二叉树:过程理解为先序
void CreateBiTree(BiTree &T)
{
TElemType ch;
cin >> ch;
if (ch == '#')
T = NULL;
else
{
T = (BiTree)malloc(sizeof(BiTNode));
if (T == NULL)
{
cout << "Create BinaryTree failed!";
exit(OverFlow);
}
T->data = ch;
CreateBiTree(T->lchild);
CreateBiTree(T->rchild);
}
} //先序遍历
void PreOrderTraverse(BiTree T)
{
if (T == NULL)
return;
cout << T->data;
PreOrderTraverse(T->lchild);
PreOrderTraverse(T->rchild);
} //深度优先遍历 //广度优先遍历 //层次遍历
void LevelTraverse(BiTree T)
{
BiTree temp;
queue<BiTree>q;
q.push(T);
do
{
temp = q.front();
cout << temp->data;
q.pop();
if (temp->lchild != NULL)
{
q.push(temp->lchild);
}
if (temp->rchild != NULL)
{
q.push(temp->rchild);
}
} while (!q.empty());
} //前面是二叉树,下面是线索二叉树
BiThrTree pre; void CreateBiThrTree(BiThrTree &T)
{
TElemType ch;
cin >> ch;
if (ch == '#')
T = NULL;
else
{
T = (BiThrTree)malloc(sizeof(BiThrNode));
if (T == NULL)
{
cout << "Create BinaryTree failed!";
exit(OverFlow);
}
T->data = ch;
CreateBiThrTree(T->lchild);
CreateBiThrTree(T->rchild);
}
} void SetPointerTag(BiThrTree &p) //实际上只需要设置初始值就行
{
if (p)
{
p->LTag = Link;
p->RTag = Link;
SetPointerTag(p->lchild);
SetPointerTag(p->rchild);
}
}
void InThreading(BiThrTree &p) //p:present
{
if (p)
{
InThreading(p->lchild);
//两个if都是线索结点
if (p->lchild == NULL) //这里千万不要写错,要看清楚:这里是没有左孩子,而不是有左孩子
{
p->LTag = Thread;
p->lchild = pre;
}
if (pre->rchild == NULL) //前驱没有右孩子
{
pre->RTag = Thread;
pre->rchild = p;
}
pre = p;
InThreading(p->rchild);
}
} //建立头结点,中序线索二叉树本来的其余结点
Status InOrderThread_Head(BiThrTree &head, BiThrTree &T)
{
if (head == NULL)
{
return ERROR;
} head->rchild = head;
head->RTag = Link; if (T == NULL) //如果为NULL
{
head->lchild = head;
head->LTag = Link;
}
else
{
pre = head;
head->lchild = T; //第一步
head->LTag = Link;
SetPointerTag(T);
InThreading(T); //找到最后一个结点
pre->rchild = head; //第四步
pre->RTag = Thread;
head->rchild = pre; //第二步
}
return OK;
} Status InOrderTraverse_Thr(BiThrTree T)
{
BiThrTree p;
p = T->lchild;
while (p != T)
{
while (p->LTag == Link)
p = p->lchild;
cout << p->data;
while (p->RTag == Thread && p->rchild != T)
{
p = p->rchild;
cout << p->data;
}
p = p->rchild;
}
return OK;
}

//Main.cpp

#include "Header.h"

int main()
{
int choice;
cout << "1:普通二叉树" << endl << "2:线索二叉树" << endl;
cin >> choice;
switch (choice)
{
case :
BiTree binaryTree;
CreateBiTree(binaryTree);
PreOrderTraverse(binaryTree);
cout << endl;
LevelTraverse(binaryTree);
cout << endl;
break;
case :
//必须用一个新的函数,新建一个树,因为数据结构已被改变——>然后建立头节点(就像链表),
//并随即线索化——>像链表一样遍历(相对于普通树的遍历,减少了递归的堆栈导致的返回次数)
BiThrTree threadBinaryTree;
CreateBiThrTree(threadBinaryTree);
BiThrTree head = (BiThrTree)malloc(sizeof(BiThrNode));
InOrderThread_Head(head, threadBinaryTree);
InOrderTraverse_Thr(head);
cout << endl;
break;
}
return ;
}

Tree的更多相关文章

  1. [数据结构]——二叉树(Binary Tree)、二叉搜索树(Binary Search Tree)及其衍生算法

    二叉树(Binary Tree)是最简单的树形数据结构,然而却十分精妙.其衍生出各种算法,以致于占据了数据结构的半壁江山.STL中大名顶顶的关联容器--集合(set).映射(map)便是使用二叉树实现 ...

  2. SAP CRM 树视图(TREE VIEW)

    树视图可以用于表示数据的层次. 例如:SAP CRM中的组织结构数据可以表示为树视图. 在SAP CRM Web UI的术语当中,没有像表视图(table view)或者表单视图(form view) ...

  3. 无限分级和tree结构数据增删改【提供Demo下载】

    无限分级 很多时候我们不确定等级关系的层级,这个时候就需要用到无限分级了. 说到无限分级,又要扯到递归调用了.(据说频繁递归是很耗性能的),在此我们需要先设计好表机构,用来存储无限分级的数据.当然,以 ...

  4. 2000条你应知的WPF小姿势 基础篇<45-50 Visual Tree&Logic Tree 附带两个小工具>

    在正文开始之前需要介绍一个人:Sean Sexton. 来自明尼苏达双城的软件工程师.最为出色的是他维护了两个博客:2,000Things You Should Know About C# 和 2,0 ...

  5. Leetcode 笔记 110 - Balanced Binary Tree

    题目链接:Balanced Binary Tree | LeetCode OJ Given a binary tree, determine if it is height-balanced. For ...

  6. Leetcode 笔记 100 - Same Tree

    题目链接:Same Tree | LeetCode OJ Given two binary trees, write a function to check if they are equal or ...

  7. Leetcode 笔记 99 - Recover Binary Search Tree

    题目链接:Recover Binary Search Tree | LeetCode OJ Two elements of a binary search tree (BST) are swapped ...

  8. Leetcode 笔记 98 - Validate Binary Search Tree

    题目链接:Validate Binary Search Tree | LeetCode OJ Given a binary tree, determine if it is a valid binar ...

  9. Leetcode 笔记 101 - Symmetric Tree

    题目链接:Symmetric Tree | LeetCode OJ Given a binary tree, check whether it is a mirror of itself (ie, s ...

  10. Tree树节点选中及取消和指定节点的隐藏

    指定节点变色 指定节点隐藏 单击节点 未选中则选中该节点 已选中则取消该节点 前台: 1.HTML <ul id="listDept" name="listDept ...

随机推荐

  1. linux 修改home 目录

         第一种方法:vi /etc/passwd 找到要修改的用户那几行,修改掉即可.此法很暴力,建议慎用. /etc/passwd文件格式 登录名:加密口令:数字用户ID:数字组ID:注释字段:起 ...

  2. 免费真机调试 -- Xcode7

    刚新安装了Xcode7 Version 7.1 beta , 据说这个版本可以免费真机调试,于是用了一个新的AppID测试了,发现真的可以免费真机调试了呢!新的appId账号,没有支付每年的99美刀, ...

  3. TextView显示颜色高亮的问题

    TextView textView = (TextView) findViewById( R.id.tv ); String text = "<font color=\"#d ...

  4. 我的Android六章:Android中SQLite数据库操作

    今天学习的内容是Android中的SQLite数据库操作,在讲解这个内容之前小编在前面有一篇博客也是讲解了SQLite数据库的操作,而那篇博客的讲解是讲述了 如何在Window中通过DOM来操作数据库 ...

  5. 基于Metaweblog API 接口一键发布到国内外主流博客平台

    之前的生活 之前一直使用evenote写博客和日志,其实还是挺方便的.但是我一直都希望能够同步到国内的博客和国外的blogspot等主流博客平台.而强大everote只提供了facebook.twit ...

  6. Iconfont-阿里巴巴矢量图标库

    http://iconfont.cn/ 网站为:

  7. view组件的duplicateParentState属性

    今天做页面的时候遇到一个小问题,在点击的时候改变组件的图片来源,这个很简单大家都知道,用selector可以很快实现.但是现状有点特殊,是 LinearLayout 中包裹着一个 ImageView ...

  8. [Linux监控]磁盘空间大小

    echo 192.168.10.69>>ip.list ------------------------------------------- #!/bin/bash #注意if和[]之间 ...

  9. 十五天精通WCF——终结篇 那些你需要注意的坑

    终于一路走来,到了本系列的最后一篇了,这一篇也没什么好说的,整体知识框架已经在前面的系列文章中讲完了,wcf的配置众多,如果 不加一些指定配置,你可能会遇到一些灾难性的后果,快来一睹为快吧. 一: 第 ...

  10. MySQL运行状态show status中文详解(转)

    要查看MySQL运行状态,要优化MySQL运行效率都少不了要运行show status查看各种状态,下面是参考官方文档及网上资料整理出来的中文详细解释: 状态名 作用域 详细解释 Aborted_cl ...