创建二叉树 二叉树如何删除节点操作教程

2016-02-19 11:52 47 1 收藏

下面是个简单易学的创建二叉树 二叉树如何删除节点操作教程教程,图老师小编详细图解介绍包你轻松学会,喜欢的朋友赶紧get起来吧!

【 tulaoshi.com - 编程语言 】

代码如下:

// 二叉树.cpp : 定义控制台应用程序的入口点。
//
/*
*二叉树作业
*2012.12.1 13:55
*Made By Karld Vorn Doenitz
*/
#include "stdafx.h"
#includeiostream
#includestring
using namespace std;
class TreeNode{//建立节点类
public:
char num;
TreeNode *leftchild,*rightchild;
};
class Queue{//建立队列类
public:
int front,rear;
TreeNode *elem;
};
void cmd();
void initQueue(Queue *q);
bool isEmpty(Queue *q);
void enQueue(Queue *q,TreeNode *e);
void outQueue(Queue *q,TreeNode *e);
void createBiTree(TreeNode * &T);
TreeNode* PreFind(TreeNode *T,char da);
void order(TreeNode *T);
void midOrder(TreeNode * T);
void addChild(TreeNode *T,char clue,char add,string side);
void deleteNode(TreeNode *T,char delchar);
int main(){//主函数
cmd();
return 0;
}
void cmd(){//命令函数
/*
*以下为命令行指令
*共有六种命令
*/
char commands;
TreeNode *T=NULL;
cout"*""___________命令如下_______________"endl;
cout"*""1、按下c键先序创建二叉树; ""*"endl;
cout"*""2、按下m键中序递归遍历二叉树; ""*"endl;
cout"*""3、按下o键层次遍历二叉树; ""*"endl;
cout"*""4、按下s键给定元素查找节点; ""*"endl;
cout"*""5、按下i键指定位置插入节点; ""*"endl;
cout"*""6、按下d键删除指定的节点; ""*"endl;
cout"*""请输入你的选择: ""*"endl;
cout"*""__________________________________"endl;
cincommands;
while(commands){
/*
*采用switch语句
*while循环
*/
switch (commands){
case 'c':
{
cout"输入要创建的二叉树,以#为空节点。"endl;
createBiTree(T);
}break;
case 'm':
{ if(T==NULL)cout"此二叉树为空,请先创建二叉树!!!"endl;
else{
cout"中序遍历二叉树的结果为:";
midOrder(T);
coutendl;}
}break;
case 'o':{
if(T==NULL)cout"此二叉树为空,请先创建二叉树!!!"endl;
else{cout"层次遍历二叉树的结果为:";
order(T);
coutendl;
} }break;
case 's':{char ch;
cout"输入要查找的元素:"endl;
cinch;
cout"要找的节点的左孩子是:";
TreeNode *bt=PreFind(T,ch);
if(bt-leftchild!=NULL)
coutbt-leftchild-numendl;
else cout"此节点是叶子,无左孩子!!!"endl;
cout"要找的节点的右孩子是:";
if(bt-rightchild!=NULL)
coutbt-rightchild-numendl;
else cout"此节点是叶子,无右孩子!!!"endl;
}break;
case 'i':{char clue,add;
string side;
cout"输入插入位置:";
cinclue;
cout"输入插入的元素:";
cinadd;
cout"选择要插入的是左子树(请输入left)还是右子树(请输入right)";
cinside;
addChild(T,clue,add,side);
}break;
case 'd':{
char del;
cout"输入要删除的节点的元素值:"endl;
cindel;
deleteNode(T,del);
}break;
default:cout"输入选择非法";break;
}
cout"输入你的选择:"endl;
cincommands;
}
}
void initQueue(Queue *q){//初始化队列
q-elem=new TreeNode;
q-front=q-rear=0;
}
bool isEmpty(Queue *q){//检查队列是否为空
if(q-front==q-rear)
return true;//队为空
else return false;//队不为空
}
void enQueue(Queue *q,TreeNode *e){//入队
q-elem[q-rear]=*e;
q-rear++;
}
void outQueue(Queue *q,TreeNode *e){//出队
if(q-front==q-rear)return;
*e=q-elem[q-front];
q-front++;
}
void createBiTree(TreeNode * &T){//创建二叉树
char ch;
cinch;
if(ch=='#') T=NULL;
else {//采用递归先序创建二叉树
T=new TreeNode;
T-num=ch;
createBiTree(T-leftchild);
createBiTree(T-rightchild);
}
}
TreeNode* PreFind(TreeNode *T,char da){//给定元素值查找结点指针位置并返回其指针,此方法采用的先序遍历
TreeNode *temp;
TreeNode *tree[20];
int top=0;
while(T!=NULL||top!=0){
while(T!=NULL){
if(T-num==da)
temp=T;
top++;
tree[top]=T;
T=T-leftchild;
}
if(top!=0){
T=tree[top]-rightchild;
top--;
}
}
return temp;
}
void order(TreeNode *T){//层序遍历二叉树
Queue *q=new Queue;
TreeNode *p=new TreeNode;
if(T!=NULL) {
initQueue(q);
enQueue(q,T);
while(!isEmpty(q)){//将根节点的左右两个子节点推入队内
outQueue(q,p);
coutp-num" ";
if(p-leftchild!=NULL)
enQueue(q,p-leftchild);
if(p-rightchild!=NULL)
enQueue(q,p-rightchild);
}
}else
cout"此二叉树为空!!!";
}
void midOrder(TreeNode * T){//二叉树中序递归遍历
if(T!=NULL){
midOrder(T-leftchild);//中序遍历T的左子树
coutT-num" "; //访问根节点
midOrder(T-rightchild);//中序遍历T的右子树
}
}
void addChild(TreeNode *T,char clue,char add,string side){//插入左右孩子操作,根据clue查找节点,由side决定插入左孩子还是右孩子
TreeNode *&late=new TreeNode;
late-num=add;
late-leftchild=NULL;
late-rightchild=NULL;
TreeNode *original=PreFind(T,clue);//查找指定的节点
if(side=="left"){
if(original-leftchild==NULL){//根结点的左孩子结点为空
original-leftchild=late;
}
}else{
if(original-rightchild==NULL){//根结点的右孩子结点为空
original-rightchild=late;
}
}
}
void deleteNode(TreeNode *T,char delchar){ //删除节点及其子节点
if (T!=NULL){//如果根节点不为空
if (T-num==delchar){//如果根节点为要删除的节点
delete T-leftchild;//删除左孩子节点
T-leftchild=NULL;//左指针指向NULL
delete T-rightchild;//删除右孩子节点
T-rightchild=NULL;//右指针指向NULL
delete T;//删除节点T
}else if (T-leftchild!=NULL&&T-leftchild-num==delchar){//如果左孩子为要删除的节点
delete T-leftchild-leftchild;//先删除左孩子的左孩子
delete T-leftchild-rightchild;//再删除左孩子的右孩子
delete T-leftchild;//最后删除左孩子
T-leftchild=NULL;//左指针为空
}else if (T-rightchild!=NULL&&T-rightchild-num==delchar){//如果右孩子为要删除的节点
delete T-rightchild-leftchild;//先删除右孩子的左孩子
delete T-rightchild-rightchild;//再删除右孩子的右孩子
delete T-rightchild;//最后删除右孩子
T-rightchild=NULL;//右指针为空
}else {
if(T-leftchild!=NULL){ //如果左孩子不为空
deleteNode(T-leftchild,delchar);//删除左孩子结点
}if(T-rightchild!=NULL){ //如果右孩子不为空
deleteNode(T-rightchild,delchar);//删除右孩子节点
}
}
}
}

来源:http://www.tulaoshi.com/n/20160219/1598942.html

延伸阅读
树 因为现实世界中存在这“树”这种结构——族谱、等级制度、目录分类等等,而为了研究这类问题,必须能够将树储存,而如何储存将取决于所需要的操作。这里有个问题,是否答应存在空树。 !-- frame contents -- !-- /frame contents -- 有些书认为树都是非空的,因为树表示的是一种现实结构,而0不是自然数;我用过的...
才刚开了个头,就要说再见了——在树这里,除了二叉树,别的都还没有讲。为什么可以总结了呢?因为前面已经涉及到了树的两个基本用途,而假如再讲B+、B-,就不能不提到搜索,假如是胜者树就不能不提到排序。为此,把这部分放到后面。 !-- frame contents -- !-- /frame contents -- 我前面所做的努力,只是让你有个基本概念,什么...
一棵二叉查找树是按二叉树结构来组织的。这样的树可以用链表结构表示,其中每一个结点都是一个对象。结点中除了数据外,还包括域left,right和p,它们分别指向结点的左儿子、右儿子,如果结点不存在,则为NULL。 它或者是一棵空树;或者是具有下列性质的二叉树: 1)若左子树不空,则左子树上所有结点的值均小于它的根结点的值; (2)若右子树...
clone模式在平衡排序二叉树实现中的应用 作者:wujinglong 下载本文示例源代码 clone模式既prototype模式,是构造模式中的一种。其意图为:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。 关键代码如下: virtual product * prototype::clone(){return new p...
本课主题: 实验七 查找 教学目的: 练习顺序查找、折半查找及二叉排序树的实现 教学重点: 教学难点: 授课内容: 顺序查找 折半查找 顺序查找及折半查找示例 二叉排序树 示例

经验教程

706

收藏

27
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部