资源简介
二叉树c++源代码实现查找,删除,插入等二叉树必须的操作。调试通过,函数中注释掉的为各模块的试验例子

代码片段和文件信息
#include“BinTree.h“
void BinTree::Insert(BinTreeNode * rootint val)
{
BinTreeNode *p=root*q=p;
BinTreeNode *node=new BinTreeNode(valNULLNULL);
while(p!=NULL)
{
q=p;
if(p->key p=p->right;
else
p=p->left;
}
if(q->key<=val)
{
q->right=node;
}
else
{
q->left=node;
}
}
BinTreeNode * BinTree::CreateBinTree (int *aint len)
{
cout<<“CreateBinTree start!“< BinTreeNode *root;//*p*q;
root=new BinTreeNode;
//p=root;q=root;
if(root->key==-1)
{
BinTreeNode *node=new BinTreeNode(a[0]NULLNULL);
root=node;
}
else
Insert(roota[0]);
for(int i=1;i {
Insert(roota[i]);
}
cout<<“Create over“< return root;
}
int BinTree::GetMiniMum(BinTreeNode * root)
{
BinTreeNode *p=root;
while(p->left!=NULL)
{
p=p->left;
}
return p->key;
}
BinTreeNode * BinTree::GetMiniNode(BinTreeNode * root)
{
BinTreeNode *p=root;
while(p->left!=NULL)
{
p=p->left;
}
return p;
}
int BinTree::GetMaxiMum(BinTreeNode *root)
{
BinTreeNode *p=root*q=p;
while(p!=NULL)
{
q=p;
p=p->right;
}
return q->key;
}
BinTreeNode *BinTree::GetMaxiNode(BinTreeNode *root)
{
BinTreeNode *p=root*q=p;
while(p!=NULL)
{
q=p;
p=p->right;
}
return q;
}
int BinTree::GetHeight(BinTreeNode *root)
{
//BinTreeNode *p=root;
if(root==NULL)
return 0;
else
{
int lh=GetHeight(root->left );
int rh=GetHeight(root->right );
return 1+(lh>rh?lh:rh);
}
}
void BinTree::InOrder(BinTreeNode *root)
{
if(root!=NULL)
{
InOrder(root->left );
cout<key <<“ “;
InOrder(root->right);
}
}
BinTreeNode * BinTree::Search(BinTreeNode * rootint key)
{
BinTreeNode *p=root;
while(p!=NULL&&p->key!=key)
{
if(p->key p=p->right ;
else
p=p->left ;
}
return p;
/*if(p==NULL)
return 0;
else
return 1;*/
}
BinTreeNode * BinTree::ParentNode(BinTreeNode * rootBinTreeNode *node)
{
BinTreeNode *p=root*q=p;
if(node->key==root->key)
{
q=NULL;
}
else
{
while(p!=NULL&&(p->key)!=(node->key))
{
q=p;
if(p->key<=node->key)
p=p->right;
else
p=p->left ;
}
}
//cout<key< return q;
}
BinTreeNode * BinTree::Sucessor(BinTreeNode * rootBinTreeNode *node)
{
if(node->right!=NULL)
{
return GetMiniNode(node->right );
}
else
{
//int num=1;
BinTreeNode *p=node*q;
q=ParentNode(rootp);
// cout<key< //cout<<“wile will be call“< while(q!=NULL&&q->left!=p)
{
p=q;
q=ParentNode(rootp);
//cout< //cout<key < }
return q;
}
}
BinTreeNode * BinTree::Sucessor(BinTreeNode * rootint key)
{
BinTreeNode *node=Search(rootkey);
if(node->right!=NULL)
{
return GetMiniNode(node->right );
}
else
{
//int num=1;
BinTreeNode *p=node*q;
q=ParentNode(rootp);
// cout<
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 0 2012-11-09 20:14 BinTree\
文件 4087 2012-11-09 20:05 BinTree\BinTree.cpp
文件 1218 2012-11-09 20:00 BinTree\BinTree.h
文件 1720 2012-11-09 20:13 BinTree\main.cpp
相关资源
- 国际象棋的qt源代码
- C语言开发实战宝典
- C++中头文件与源文件的作用详解
- C++多线程网络编程Socket
- VC++ 多线程文件读写操作
- 利用C++哈希表的方法实现电话号码查
- 移木块游戏,可以自编自玩,vc6.0编写
- C++纯文字DOS超小RPG游戏
- 小甲鱼C语言课件 源代码
- VC++MFC小游戏实例教程(实例)+MFC类库
- c语言看发的网络协议 ,源代码
- C语言实现的DES对称加密算法
- 数据结构,迷宫问题C语言版源代码
- C语言 学生信息管理系统 源代码
- C语言版3D魔方游戏源代码
- 连铸温度场计算程序(C++)
- 6自由度机器人运动学正反解C++程序
- Em算法(使用C++编写)
- libstdc++-4.4.7-4.el6.i686.rpm
- VC++实现CMD命令执行与获得返回信息
- 白话C++(全)
- C++标准库第1、2
- 大数类c++大数类
- C++语言编写串口调试助手
- c++素数筛选法
- QT5开发及源代码
- C++ mqtt 用法
- 商品库存管理系统 C++ MFC
- c++ 多功能计算器
- C++17 In Detail
评论
共有 条评论