#ifndef _Tree_H #define _Tree_H struct TreeNode; typedef struct TreeNode* Position; typedef struct TreeNode* SearchTree; void CreateTree(SearchTree &T); SearchTree Delete(int x, SearchTree T); SearchTree FindMin(SearchTree T); SearchTree Insert(int x, SearchTree T); Position Find(int x, SearchTree T); SearchTree MakeEmpty(SearchTree T); void PrintTree(SearchTree T); struct TreeNode { int e; SearchTree Left; SearchTree Right; }; #endif
void CreateTree(SearchTree &T) { int c; scanf("%d", &c); if (c == -1) { T = NULL; } else { T = (SearchTree)malloc(sizeof(TreeNode)); T->e = c; CreateTree(T->Left); CreateTree(T->Right); } }
輸入-1,該指針值爲NULLspa
void PrintTree(SearchTree T) { if (T) { cout << T->e << " "; PrintTree(T->Left); PrintTree(T->Right); } }
SearchTree MakeEmpty(SearchTree T) { if (T != NULL) { MakeEmpty(T->Left); MakeEmpty(T->Right); free(T); } return NULL; }
Position Find(int x, SearchTree T) { if (T == NULL) { return NULL; } if (x < T->e) { return Find(x, T->Left); } else if (x > T->e) { return Find(x, T->Right); } else { return T; } }
SearchTree FindMin(SearchTree T) { if (T == NULL) { return NULL; } else if (T->Left == NULL) { return T; } else { return FindMin(T->Left); } }
SearchTree Insert(int x, SearchTree T) { if (T == NULL) { T = (SearchTree)malloc(sizeof(TreeNode)); if (T == NULL) { return NULL; } else { T->e = x; T->Left = NULL; T->Right = NULL; } } else if (x < T->e) { T->Left = Insert(x, T->Left); } else if (x > T->e) { T->Right = Insert(x, T->Right); } return T; }
SearchTree Delete(int x, SearchTree T) { Position TmpCall; if (T == NULL) { return NULL; } else if (x < T->e) { T->Left = Delete(x, T->Left); } else if (x > T->e) { T->Right = Delete(x, T->Right); } else if (T->Left && T->Right) { TmpCall = FindMin(T->Right); T->e = TmpCall->e; T->Right = Delete(T->e, T->Right); } else { TmpCall = T; if (T->Left == NULL) { T = T->Right; } else if (T->Right == NULL) { T = T->Left; } free(TmpCall); } return T; }