⑴ 对给定的一组无序序列,建立一棵二叉排序树; ⑵ 对建立的二叉排序树实现查找操作。求用c语言实现的代码
时间: 2024-02-16 12:03:59 浏览: 23
以下是用 C 语言实现的代码:
```c
#include <stdio.h>
#include <stdlib.h>
typedef struct node {
int data;
struct node *left;
struct node *right;
} Node;
Node* create_node(int data) {
Node* new_node = (Node*)malloc(sizeof(Node));
new_node->data = data;
new_node->left = NULL;
new_node->right = NULL;
return new_node;
}
Node* insert(Node *root, int data) {
if (root == NULL) {
return create_node(data);
}
if (data < root->data) {
root->left = insert(root->left, data);
} else if (data > root->data) {
root->right = insert(root->right, data);
}
return root;
}
Node* search(Node *root, int data) {
if (root == NULL || root->data == data) {
return root;
}
if (data < root->data) {
return search(root->left, data);
}
return search(root->right, data);
}
void inorder_traversal(Node *root) {
if (root == NULL) {
return;
}
inorder_traversal(root->left);
printf("%d ", root->data);
inorder_traversal(root->right);
}
int main() {
Node *root = NULL;
int arr[] = {5, 3, 7, 1, 9, 2, 4, 6, 8};
int n = sizeof(arr) / sizeof(arr[0]);
for (int i = 0; i < n; i++) {
root = insert(root, arr[i]);
}
inorder_traversal(root);
printf("\n");
int search_key = 6;
Node *result = search(root, search_key);
if (result == NULL) {
printf("%d not found\n", search_key);
} else {
printf("%d found\n", result->data);
}
return 0;
}
```
这个程序中,我们首先定义了一个二叉树节点结构体 `Node`。然后,我们定义了两个函数 `create_node` 和 `insert`,分别用于创建节点和插入节点。
在 `insert` 函数中,我们首先判断根节点是否为空。如果为空,就创建一个新节点并返回。否则,我们根据节点值的大小,将新节点插入到左子树或右子树中。
接下来,我们定义了另一个函数 `search`,用于在二叉排序树中查找一个节点。如果找到了,就返回该节点;否则,返回 NULL。
最后,我们定义了一个函数 `inorder_traversal`,用于中序遍历二叉排序树。我们用一个数组来初始化二叉排序树,然后调用 `inorder_traversal` 函数来输出排序后的结果。
在 `main` 函数中,我们首先用一个数组来初始化二叉排序树。然后,我们调用 `inorder_traversal` 函数来输出排序后的结果。最后,我们用 `search` 函数来查找节点,并输出结果。