二叉搜索树 - Binary Search Tree

实验内容

建立中序线索二叉树,并实现中序遍历

代码实现

1.为字符串建BST

typedef struct TreeNode {
    char* data;
    struct TreeNode* left;
    struct TreeNode* right;
} TreeNode;

// 创建新节点
TreeNode* createNode(char* data) {
    TreeNode* newNode = (TreeNode*)malloc(sizeof(TreeNode));
    if (newNode == NULL) {
        fprintf(stderr, "Memory allocation failed\n");
        exit(EXIT_FAILURE);
    }
    newNode->data = _strdup(data);
    if (newNode->data == NULL) {
        fprintf(stderr, "Memory allocation failed\n");
        exit(EXIT_FAILURE);
    }
    newNode->left = NULL;
    newNode->right = NULL;
    return newNode;
}

// 插入节点到二叉树
TreeNode* insertNode(TreeNode* root, char* data) {
    if (root == NULL) {
        return createNode(data);
    }

    if (strcmp(data, root->data) < 0) {
        root->left = insertNode(root->left, data);
    }
    else {
        root->right = insertNode(root->right, data);
    }

    return root;
}

// 创建二叉树
TreeNode* createBinaryTree(char* data[], int size) {
    TreeNode* root = NULL;
    for (int i = 0; i < size; i++) {
        root = insertNode(root, data[i]);
    }
    return root;
}

// 中序遍历打印二叉树
void inorderTraversal(TreeNode* root) {
    if (root != NULL) {
        inorderTraversal(root->left);
        printf("%s ", root->data);
        inorderTraversal(root->right);
    }
}

// 释放二叉树
void freeTree(TreeNode* root) {
    if (root != NULL) {
        freeTree(root->left);
        freeTree(root->right);
        free(root->data);
        free(root);
    }
}

void test() {
    int size;
    printf("\nEnter the number of strings: ");
    scanf("%d", &size);

    // 动态分配数组来存储字符串
    char** data = (char**)malloc(size * sizeof(char*));
    if (data == NULL) {
        fprintf(stderr, "Memory allocation failed\n");
        exit(EXIT_FAILURE);
    }

    // 读取字符串
    for (int i = 0; i < size; i++) {
        char buffer[100]; // 假设每个字符串最多100字符
        printf("Enter string %d: ", i + 1);
        scanf("%s", buffer);
        data[i] = _strdup(buffer);
        if (data[i] == NULL) {
            fprintf(stderr, "Memory allocation failed\n");
            exit(EXIT_FAILURE);
        }
    }

    TreeNode* root = createBinaryTree(data, size);

    printf("\nInorder traversal of the binary tree:\n");
    inorderTraversal(root);
    printf("\n");

    freeTree(root);

    // 释放字符串数组
    for (int i = 0; i < size; i++) {
        free(data[i]);
    }
    free(data);
}

int main() {
    printf("**************Character Sequence Binary Search Tree**********************\n");
    test();
    return 0;
}

//Banana Apple Cherry Mango Blueberry Orange Strawberry Grape Watermelon Pear

结果展示 

2.为字符序列建BST

// 定义二叉树节点结构
typedef struct TreeNode {
    char data;
    struct TreeNode* left;
    struct TreeNode* right;
} TreeNode;

// 创建新节点
TreeNode* createNode(char data) {
    TreeNode* newNode = (TreeNode*)malloc(sizeof(TreeNode));
    if (newNode == NULL) {
        fprintf(stderr, "Memory allocation failed\n");
        exit(EXIT_FAILURE);
    }
    newNode->data = data;
    newNode->left = NULL;
    newNode->right = NULL;
    return newNode;
}

// 插入节点到二叉树
TreeNode* insertNode(TreeNode* root, char data) {
    if (root == NULL) {
        return createNode(data);
    }

    if (data < root->data) {
        root->left = insertNode(root->left, data);
    }
    else {
        root->right = insertNode(root->right, data);
    }

    return root;
}

// 创建二叉树
TreeNode* createBinaryTree(char data[], int size) {
    TreeNode* root = NULL;
    for (int i = 0; i < size; i++) {
        root = insertNode(root, data[i]);
    }
    return root;
}

// 中序遍历打印二叉树
void inorderTraversal(TreeNode* root) {
    if (root != NULL) {
        inorderTraversal(root->left);
        printf("%c ", root->data);
        inorderTraversal(root->right);
    }
}

// 释放二叉树
void freeTree(TreeNode* root) {
    if (root != NULL) {
        freeTree(root->left);
        freeTree(root->right);
        free(root);
    }
}

void test() {
    printf("**************Character Sequence Binary Search Tree**********************\n");
    printf("\nEnter the Character Sequence : ");
    char ch[100];
    scanf("%s", ch);
    int size = strlen(ch);

    TreeNode* root = createBinaryTree(ch, size);
    printf("\nInorder traversal of the binary tree: ");
    inorderTraversal(root);
    printf("\n");
    freeTree(root);
}

int main() {
    test();
    return 0;
}

 结果展示

3.优化---查找/删除字符

 

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

// 定义二叉树节点结构
typedef struct TreeNode {
    char data;
    struct TreeNode* left;
    struct TreeNode* right;
} TreeNode;

// 创建新节点
TreeNode* createNode(char data) {
    TreeNode* newNode = (TreeNode*)malloc(sizeof(TreeNode));
    if (newNode == NULL) {
        fprintf(stderr, "Memory allocation failed\n");
        exit(EXIT_FAILURE);
    }
    newNode->data = data;
    newNode->left = NULL;
    newNode->right = NULL;
    return newNode;
}

// 插入节点到二叉树
TreeNode* insertNode(TreeNode* root, char data) {
    if (root == NULL) {
        return createNode(data);
    }

    if (data < root->data) {
        root->left = insertNode(root->left, data);
    }
    else {
        root->right = insertNode(root->right, data);
    }

    return root;
}

// 查找数据
TreeNode* searchNode(TreeNode* root, char data) {
    if (root == NULL || root->data == data) {
        return root;
    }

    if (data < root->data) {
        return searchNode(root->left, data);
    }
    else {
        return searchNode(root->right, data);
    }
}

// 找到树中的最小值节点
TreeNode* findMinNode(TreeNode* root) {
    while (root->left != NULL) {
        root = root->left;
    }
    return root;
}

// 删除节点
TreeNode* deleteNode(TreeNode* root, char data) {
    if (root == NULL) {
        return root;
    }

    if (data < root->data) {
        root->left = deleteNode(root->left, data);
    }
    else if (data > root->data) {
        root->right = deleteNode(root->right, data);
    }
    else {
        // 找到要删除的节点
        if (root->left == NULL) {
            TreeNode* temp = root->right;
            free(root);
            return temp;
        }
        else if (root->right == NULL) {
            TreeNode* temp = root->left;
            free(root);
            return temp;
        }

        // 节点有两个子节点,找到右子树的最小值节点
        TreeNode* temp = findMinNode(root->right);
        root->data = temp->data;
        root->right = deleteNode(root->right, temp->data);
    }

    return root;
}

// 创建二叉树
TreeNode* createBinaryTree(char data[], int size) {
    TreeNode* root = NULL;
    for (int i = 0; i < size; i++) {
        root = insertNode(root, data[i]);
    }
    return root;
}

// 中序遍历打印二叉树
void inorderTraversal(TreeNode* root) {
    if (root != NULL) {
        inorderTraversal(root->left);
        printf("%c ", root->data);
        inorderTraversal(root->right);
    }
}

// 释放二叉树
void freeTree(TreeNode* root) {
    if (root != NULL) {
        freeTree(root->left);
        freeTree(root->right);
        free(root);
    }
}

void test() {
    printf("**************Character Sequence Binary Search Tree**********************\n");
    printf("\nEnter the Character Sequence: ");
    char ch[100];
    scanf("%s", ch);
    int size = strlen(ch);

    TreeNode* root = createBinaryTree(ch, size);
    printf("\nInorder traversal of the binary tree: ");
    inorderTraversal(root);
    printf("\n");

    char searchChar;
    printf("\nEnter the character to search: ");
    scanf(" %c", &searchChar);
    TreeNode* foundNode = searchNode(root, searchChar);
    if (foundNode) {
        printf("Character '%c' found in the tree.\n", searchChar);
    }
    else {
        printf("Character '%c' not found in the tree.\n", searchChar);
    }

    char deleteChar;
    printf("\nEnter the character to delete: ");
    scanf(" %c", &deleteChar);
    root = deleteNode(root, deleteChar);
    printf("\nInorder traversal after deletion: ");
    inorderTraversal(root);
    printf("\n");

    freeTree(root);
}

int main() {
    test();
    return 0;
}

结果展示

  • 10
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 二叉搜索树Binary Search Tree):是一棵空树或者具有下列性质的二叉树:若它的左子树不空,则左子树上所有节点的值均小于它的根节点的值;若它的右子树不空,则右子树上所有节点的值均大于它的根节点的值;它的左右子树也分别为二叉搜索树。 中序遍历序列:对于任意一棵二叉树,中序遍历的结果都是一个序列,这个序列称为中序遍历序列。 因此,判断一棵二叉树是否为二叉搜索树,可以先进行中序遍历,再判断遍历结果是否为升序序列。 以下是 Python 代码实现: ```python class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right def inorderTraversal(root: TreeNode) -> List[int]: res = [] if not root: return res res.extend(inorderTraversal(root.left)) res.append(root.val) res.extend(inorderTraversal(root.right)) return res def isBST(root: TreeNode) -> bool: res = inorderTraversal(root) for i in range(1, len(res)): if res[i] <= res[i-1]: return False return True ``` 其中,`TreeNode` 是二叉树的节点类,`inorderTraversal` 函数是实现二叉树中序遍历的递归函数,`isBST` 函数是判断二叉树是否为二叉搜索树的函数。 ### 回答2: 要实现这个函数,首先我们可以使用递归的方式对二叉树进行中序遍历,即先遍历左子树,再访问根节点,最后遍历右子树。遍历过程中将遍历到的节点值保存到一个数组中。 接下来,我们需要判断该数组是否是按升序排列的,即判断是否是一棵二叉搜索树。我们可以遍历数组,依次比较相邻的节点值,如果前一个节点的值大于等于后一个节点的值,则认为不是二叉搜索树。反之,如果整个数组都符合这个条件,则认为是一个二叉搜索树。 以下是一个简单的实现代码: ``` class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right def inorderTraversal(root): if not root: return [] result = [] inorder(root, result) return result def inorder(root, result): if not root: return inorder(root.left, result) result.append(root.val) inorder(root.right, result) def isBST(root): inorder_result = inorderTraversal(root) for i in range(1, len(inorder_result)): if inorder_result[i] <= inorder_result[i-1]: return False return True ``` 这个函数的时间复杂度是O(n),其中n是二叉树中节点的数量,因为我们需要遍历每个节点并将节点的值保存到数组中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值