资源简介
二叉树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
相关资源
- 傅里叶描述子的提取,并且提取手势
- C++中国象棋人机下棋 高智商版
- 编译C++需要的库文件win32 mak
- C++ Builder 2009 破解文件及序列号
- yaolog v1.5(很有特色的C++跨平台日志库
- VC++写的功能非常强大的自定义列表控
- 操作系统 课程设计 C++ 读者写着问题
- 操作系统 课程设计 C++ 模拟文件系统
- c++ http
- c++ http并保存到本地
- C++ HTTP GET,POST的简单
- 数据压缩LZW编码c++程序
- 数据压缩 算术编码 c++ 程序
- C/C++/STL帮助手册 chm完整离线版
- ECC算法 C++实现 加解密
- 高斯投影正算C++源代码
- C++课程设计——学生学籍管理系统
- 清华大学C++内部题库 绝对好题
- VC++ MFC的餐厅点餐系统
- 用c++解决金刚坐飞机问题
- C++景区旅游信息管理系统
- 实现104规约源代码
- 文件同步与异步读写
- hiredis的c++封装, 线程安全
- C++实现Apriori算法,频繁模式数据挖掘
- 线性表创建,插入,删除及合并源代
- C++获取windows系统服务
- 矩阵算法相关代码
- 点扩散函数PSF
- 潮流计算 高斯赛德尔法
评论
共有 条评论