데이터 구조 루틴 - 이 진 트 리
#include
#include
typedef int KeyType;
typedef char InfoType[10];
typedef struct node //
{
KeyType key; //
InfoType data; //
struct node *lchild,*rchild; //
} BSTNode;
// p , k
int InsertBST(BSTNode *&p,KeyType k)
{
if (p==NULL) // ,
{
p=(BSTNode *)malloc(sizeof(BSTNode));
p->key=k;
p->lchild=p->rchild=NULL;
return 1;
}
else if (k==p->key) // , 0
return 0;
else if (kkey)
return InsertBST(p->lchild,k); // *p
else
return InsertBST(p->rchild,k); // *p
}
// n A,
BSTNode *CreateBST(KeyType A[],int n) // BST
{
BSTNode *bt=NULL; // bt
int i=0;
while (i// A[i] T
i++;
}
return bt; //
}
//
void DispBST(BSTNode *bt)
{
if (bt!=NULL)
{
printf("%d",bt->key);
if (bt->lchild!=NULL || bt->rchild!=NULL)
{
printf("("); // (
DispBST(bt->lchild); //
if (bt->rchild!=NULL) printf(","); // ,
DispBST(bt->rchild); //
printf(")"); // )
}
}
}
// bt , k 。 NULL
BSTNode *SearchBST(BSTNode *bt,KeyType k)
{
if (bt==NULL || bt->key==k) //
return bt;
if (kkey)
return SearchBST(bt->lchild,k); //
else
return SearchBST(bt->rchild,k); //
}
//
BSTNode *SearchBST1(BSTNode *bt,KeyType k)
{
while (bt!=NULL)
{
if (k==bt->key)
return bt;
else if (kkey)
bt=bt->lchild;
else
bt=bt->rchild;
}
return NULL;
}
void Delete1(BSTNode *p,BSTNode *&r) // *p
{
BSTNode *q;
if (r->rchild!=NULL)
Delete1(p,r->rchild); //
else // *r
{
p->key=r->key; // *r *p
q=r;
r=r->lchild; //
free(q); // *r
}
}
void Delete(BSTNode *&p) // *p
{
BSTNode *q;
if (p->rchild==NULL) //*p
{
q=p;
p=p->lchild; //
free(q);
}
else if (p->lchild==NULL) //*p
{
q=p;
p=p->rchild; // *p
free(q);
}
else Delete1(p,p->lchild); //*p
}
int DeleteBST(BSTNode *&bt, KeyType k) // bt k
{
if (bt==NULL)
return 0; //
else
{
if (kkey)
return DeleteBST(bt->lchild,k); // k
else if (k>bt->key)
return DeleteBST(bt->rchild,k); // k
else
{
Delete(bt); // Delete(bt) *bt
return 1;
}
}
}
int main()
{
BSTNode *bt;
int n=12,x=46;
KeyType a[]= {25,18,46,2,53,39,32,4,74,67,60,11};
bt=CreateBST(a,n);
printf("BST:");
DispBST(bt);
printf("
");
printf(" %d
",x);
if (SearchBST(bt,x)!=NULL)
{
DeleteBST(bt,x);
printf("BST:");
DispBST(bt);
printf("
");
}
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.