91av视频/亚洲h视频/操亚洲美女/外国一级黄色毛片 - 国产三级三级三级三级

  • 大小: 2KB
    文件類型: .zip
    金幣: 2
    下載: 0 次
    發布日期: 2021-06-10
  • 語言: C/C++
  • 標簽: 二叉樹??c++??源代碼??

資源簡介

二叉樹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

評論

共有 條評論