04-树7 二叉搜索树的操作集 (30 分)

本题要求实现给定二叉搜索树的5种常用操作。

函数接口定义:

BinTree Insert( BinTree BST, ElementType X );
BinTree Delete( BinTree BST, ElementType X );
Position Find( BinTree BST, ElementType X );
Position FindMin( BinTree BST );
Position FindMax( BinTree BST );

其中BinTree结构定义如下:

typedef struct TNode *Position;
typedef Position BinTree;
struct TNode{ElementType Data;BinTree Left;BinTree Right;
};
  • 函数InsertX插入二叉搜索树BST并返回结果树的根结点指针;
  • 函数DeleteX从二叉搜索树BST中删除,并返回结果树的根结点指针;如果X不在树中,则打印一行Not Found并返回原树的根结点指针;
  • 函数Find在二叉搜索树BST中找到X,返回该结点的指针;如果找不到则返回空指针;
  • 函数FindMin返回二叉搜索树BST中最小元结点的指针;
  • 函数FindMax返回二叉搜索树BST中最大元结点的指针。

裁判测试程序样例:

#include <stdio.h>
#include <stdlib.h>typedef int ElementType;
typedef struct TNode *Position;
typedef Position BinTree;
struct TNode{ElementType Data;BinTree Left;BinTree Right;
};void PreorderTraversal( BinTree BT ); /* 先序遍历,由裁判实现,细节不表 */
void InorderTraversal( BinTree BT );  /* 中序遍历,由裁判实现,细节不表 */BinTree Insert( BinTree BST, ElementType X );
BinTree Delete( BinTree BST, ElementType X );
Position Find( BinTree BST, ElementType X );
Position FindMin( BinTree BST );
Position FindMax( BinTree BST );int main()
{BinTree BST, MinP, MaxP, Tmp;ElementType X;int N, i;BST = NULL;scanf("%d", &N);for ( i=0; i<N; i++ ) {scanf("%d", &X);BST = Insert(BST, X);}printf("Preorder:"); PreorderTraversal(BST); printf("\n");MinP = FindMin(BST);MaxP = FindMax(BST);scanf("%d", &N);for( i=0; i<N; i++ ) {scanf("%d", &X);Tmp = Find(BST, X);if (Tmp == NULL) printf("%d is not found\n", X);else {printf("%d is found\n", Tmp->Data);if (Tmp==MinP) printf("%d is the smallest key\n", Tmp->Data);if (Tmp==MaxP) printf("%d is the largest key\n", Tmp->Data);}}scanf("%d", &N);for( i=0; i<N; i++ ) {scanf("%d", &X);BST = Delete(BST, X);}printf("Inorder:"); InorderTraversal(BST); printf("\n");return 0;
}
/* 你的代码将被嵌在这里 */

输入样例:

10
5 8 6 2 4 1 0 10 9 7
5
6 3 10 0 5
5
5 7 0 10 3

输出样例:

Preorder: 5 2 1 0 4 8 6 7 10 9
6 is found
3 is not found
10 is found
10 is the largest key
0 is found
0 is the smallest key
5 is found
Not Found
Inorder: 1 2 4 6 8 9
#include<stdio.h>
#include<stdlib.h>typedef int ElementType;
typedef struct TNode* Position;
typedef Position BinTree;struct TNode{ElementType Data;BinTree Left;BinTree Right;
};void PreorderTraversal(BinTree BT);
void InorderTraversal(BinTree BT);Position FindMin(BinTree BST);
Position FindMax(BinTree BST);
Position Find(BinTree BST,ElementType X);BinTree Insert(BinTree BST, ElementType X);
BinTree Delete(BinTree BST, ElementType X);int main(){BinTree BST,MinP,MaxP,Tmp;ElementType X;int N,i;BST = NULL;scanf("%d",&N);for(i = 0; i < N; i++){scanf("%d",&X);BST = Insert(BST,X);}printf("PreOrder:");PreorderTraversal(BST);printf("\n");MinP = FindMin(BST);MaxP = FindMax(BST); printf("%d %d\n",MinP->Data,MaxP->Data);scanf("%d",&N);for(i = 0; i < N; i++){scanf("%d",&X);Tmp = Find(BST,X);if(Tmp == NULL) printf("%d is not found\n",X);else{printf("%d is found\n",X);if(Tmp == MinP) printf("%d is the smallest key\n",Tmp->Data);if(Tmp == MaxP) printf("%d is the largest key\n",Tmp->Data);}}scanf("%d",&N);for(i = 0; i < N; i++){scanf("%d",&X);BST = Delete(BST,X);}printf("InorderTraver:");InorderTraversal(BST);return 0;
}BinTree Insert(BinTree BST, ElementType X){if(!BST){BST = (BinTree)malloc(sizeof(struct TNode));BST->Left = NULL;BST->Right = NULL;BST->Data = X;}else if(X > BST->Data){BST->Right = Insert(BST->Right,X);}else if(X < BST->Data){BST->Left = Insert(BST->Left,X);}return BST;
}void PreorderTraversal(BinTree BT){if(BT){printf("%d ",BT->Data);PreorderTraversal(BT->Left);PreorderTraversal(BT->Right);}else return;
}Position FindMin(BinTree BST) {if (BST) {while (BST->Left != NULL) {BST = BST->Left;}}return BST;
}
Position FindMax(BinTree BST) {if (BST) {while (BST->Right != NULL) {BST = BST->Right;}}return BST;
}
Position Find(BinTree BST, ElementType X) {if (!BST)return NULL;if (X < BST->Data) {return Find(BST->Left, X);}else if (X > BST->Data) {return Find(BST->Right, X);}elsereturn BST;
}BinTree Delete(BinTree BST, ElementType X){BinTree p;if(!BST){printf("Not Found\n");return BST;}if(X < BST->Data) BST->Left = Delete(BST->Left,X);else if(X > BST->Data) BST->Right = Delete(BST->Right,X);else{if(BST->Left&&BST->Right){p = FindMax(BST->Left);BST->Data = p->Data;BST->Left = Delete(BST->Left,BST->Data);}else{p = BST;if(!BST->Left) BST = BST->Right;else if(!BST->Right) BST = BST->Left;free(p);}} return BST;
}void InorderTraversal(BinTree BT){if(BT){InorderTraversal(BT->Left);printf("%d ",BT->Data);InorderTraversal(BT->Right);}else return;
}

 

转载于:https://www.cnblogs.com/wanghao-boke/p/10627830.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/385085.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

02-线性结构3 Reversing Linked List (25 分)

Given a constant K and a singly linked list L, you are supposed to reverse the links of every K elements on L. For example, given L being 1→2→3→4→5→6, if K3, then you must output 3→2→1→6→5→4; if K4, you must output 4→3→2→1→5→6. Input Specifi…

03-树1 树的同构 (25 分)

给定两棵树T1和T2。如果T1可以通过若干次左右孩子互换就变成T2&#xff0c;则我们称两棵树是“同构”的。例如图1给出的两棵树就是同构的&#xff0c;因为我们把其中一棵树的结点A、B、G的左右孩子互换后&#xff0c;就得到另外一棵树。而图2就不是同构的。 图1 图2 现给定两棵…

【树】104. 二叉树的最大深度

题目 104. 二叉树的最大深度 方法1 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr),…

Leetcode 206. 反转链表

206. 反转链表 解法1 class Solution { public:ListNode *reverseList(ListNode *head){if(!head || !head->next)return head;ListNode *p;p reverseList(head->next);head->next->next head;head->next nullptr;return p;} };解法2 /*** Definition for…

05-树7 堆中的路径 (25 分)

将一系列给定数字插入一个初始为空的小顶堆H[]。随后对任意给定的下标i&#xff0c;打印从H[i]到根结点的路径。 输入格式: 每组测试第1行包含2个正整数N和M(≤)&#xff0c;分别是插入元素的个数、以及需要打印的路径条数。下一行给出区间[-10000, 10000]内的N个要被插入一个初…

Leetcode 124.二叉树中的最大路径

解法1 解法 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* …

《UNIX环境高级编程》目录

第一章&#xff1a;UNIX标准及实现 01 函数perror、strerror 第三章&#xff1a;文件I/O 01 C库函数 02 文件描述符、函数open和openat 03 函数read、write、lseek 04 函数dup和dup2 第四章&#xff1a;文件和目录 01 函数stat、fstat、fstatat和lstat 02 函数umask 03 函…

06-图1 列出连通集 (25 分)

给定一个有N个顶点和E条边的无向图&#xff0c;请用DFS和BFS分别列出其所有的连通集。假设顶点从0到N−1编号。进行搜索时&#xff0c;假设我们总是从编号最小的顶点出发&#xff0c;按编号递增的顺序访问邻接点。 输入格式: 输入第1行给出2个整数N(0)和E&#xff0c;分别是图的…

牛客网算法题题解

序号题目语言标记1 C解题报告 2 3 4字符串归一化C解题报告

06-图3 六度空间 (30 分)

“六度空间”理论又称作“六度分隔&#xff08;Six Degrees of Separation&#xff09;”理论。这个理论可以通俗地阐述为&#xff1a;“你和任何一个陌生人之间所间隔的人不会超过六个&#xff0c;也就是说&#xff0c;最多通过五个人你就能够认识任何一个陌生人。”如图1所示…

Linux网络编程目录

UNIX网络编程目录 1. TCP三次握手的第三次的 ack包丢失会怎样&#xff1f; 2. inux网络编程“惊群”问题总结

Linux高性能服务器编程

一、文件IO、标准IO 1. 2. 函数dup和dup2 三、进程 1. fork、vfork、clone 2. 函数wait、waitpid、孤儿进程、僵尸进程 3. 进程组 4. 会话 四、信号 1. 函数signal、sigaction 2. 函信号SIGCHLD 3. 函数kill、raise、abort、alarm 4. 信号集、sigprocmask、sigpending 五、…

07-图4 哈利·波特的考试 (25 分)

哈利波特要考试了&#xff0c;他需要你的帮助。这门课学的是用魔咒将一种动物变成另一种动物的本事。例如将猫变成老鼠的魔咒是haha&#xff0c;将老鼠变成鱼的魔咒是hehe等等。反方向变化的魔咒就是简单地将原来的魔咒倒过来念&#xff0c;例如ahah可以将老鼠变成猫。另外&…

C++ Primer (二)目录

第十五章&#xff1a;面向对象程序设计 1. 虚函数/2. 虚函数表剖析&#xff08;一&#xff09;3. 虚函数表剖析&#xff08;二&#xff09;4. 虚函数表剖析&#xff08;三&#xff09;

07-图6 旅游规划 (25 分)

有了一张自驾旅游路线图&#xff0c;你会知道城市间的高速公路长度、以及该公路要收取的过路费。现在需要你写一个程序&#xff0c;帮助前来咨询的游客找一条出发地和目的地之间的最短路径。如果有若干条路径都是最短的&#xff0c;那么需要输出最便宜的一条路径。 输入格式: 输…

08-图7 公路村村通 (30 分)

现有村落间道路的统计数据表中&#xff0c;列出了有可能建设成标准公路的若干条道路的成本&#xff0c;求使每个村落都有公路连通所需要的最低成本。 输入格式: 输入数据包括城镇数目正整数N&#xff08;≤&#xff09;和候选道路数目M&#xff08;≤&#xff09;&#xff1b;随…

《回溯算法》目录

序号题目标记1 46. 全排列 2 47. 全排列 II 3 39. 组合总和 4 40. 组合总和 II 5 6

08-图9 关键活动 (30 分)

假定一个工程项目由一组子任务构成&#xff0c;子任务之间有的可以并行执行&#xff0c;有的必须在完成了其它一些子任务后才能执行。“任务调度”包括一组子任务、以及每个子任务可以执行所依赖的子任务集。 比如完成一个专业的所有课程学习和毕业设计可以看成一个本科生要完成…

C++ Primer

C Primer目录索引 虚函数表剖析&#xff08;一&#xff09;虚函数表剖析&#xff08;二&#xff09;static关键字用法 volatile、const的用法​​​​​​​

10-排序4 统计工龄 (20 分)

给定公司N名员工的工龄&#xff0c;要求按工龄增序输出每个工龄段有多少员工。 输入格式: 输入首先给出正整数N&#xff08;≤&#xff09;&#xff0c;即员工总人数&#xff1b;随后给出N个整数&#xff0c;即每个员工的工龄&#xff0c;范围在[0, 50]。 输出格式: 按工龄的递…