二叉排序树删除值小于value的结点

本文介绍了如何删除二叉排序树中所有值小于10的节点。针对面试题中的场景,讨论了处理根节点小于10且右子树包含大于10节点的情况,以及复杂情况下的树结构调整。提出了通过循环查找大于10的节点进行树结构修正的思路,并给出了相应的C语言实现代码。欢迎大家交流讨论。
摘要由CSDN通过智能技术生成

还是前面那个题,同学去阿里面试的时候,要求写出代码:

   现在有一棵二叉排序树,每个节点保存一个int类型的值,删除值为10以下的节点(树中可能不含值为10的节点),说一下思路,写一下算法。

   算了原来错误的思路就不拿出来误导大家了,只能说想简单了,花了几天空闲的时间思考这个问题,终于把代码写出来了,虽然琢磨了一段时间,但是终究还是写出来了。

   经过测试数据或者自己画图,感觉有这么几个难点把

   1.如果数据是这样:6,5,7,8,15,就是先开始根结点的值小于10,后来右子树中=存在大于10的结点,由于需要释放小于10的结点,就需要重新调整根结点

   2.如果数据是这样:6,5,7,8,15,14,9,8,13,11,10,就是先开始小于10ÿ

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
好的,下面是一个用C语言实现的示代码: ```c #include <stdio.h> #include <.h> // 二叉排序树结点定义 struct TreeNode { int value; struct* left; struct TreeNode* right; }; 向二叉排序树中插入结点的函数 struct TreeNode* insertNode(struct TreeNode* root, int value) { // 如果树为空,创建新结点作为根结点 if (root == NULL) { struct TreeNode* newNode = (struct TreeNode*)malloc(sizeof(struct TreeNode)); newNode->value = value; newNode->left = NULL; newNode->right = NULL; return newNode; } // 如果插入小于当前结点,则插入到左子树中 if (value < root->value) { root->left = insertNode(root->left, value); } // 如果插入大于等于当前结点,则插入到右子树中 else { root->right = insertNode(root->right, value); } return root; } // 在二叉排序树中查找给定的函数 struct TreeNode* searchNode(struct TreeNode* root, int value) { // 如果树为空或者当前结点等于给定,返回当前结点 if (root == NULL || root->value == value) { return root; } // 如果给定小于当前结点,则在左子树中查找 if (value < root->value) { return searchNode(root->left, value); } // 如果给定大于当前结点,则在右子树中查找 else { return searchNode(root->right, value); } } // 释放二叉排序树的内存的函数 void freeTree(struct TreeNode* root) { if (root == NULL) { return; } freeTree(root->left); freeTree(root->right); free(root); } int main() { struct TreeNode* root = NULL; // 初始化根结点为空 // 输入一组数据作为二叉排序树结点 printf("请输入一组数据(以-1作为结束):\n"); int value; while (scanf("%d", &value) && value != -1) { root = insertNode(root, value); // 向二叉排序树中插入结点 } // 输入要查找的 printf("请输入要查找的:\n"); int target; scanf("%d", &target); // 在二叉排序树中查找给定 struct TreeNode* result = searchNode(root, target); // 输出查找结果 if (result == NULL) { printf("未找到该。\n"); } else { printf("已找到该。\n"); } // 释放二叉排序树的内存 freeTree(root); return 0; } ``` 你可以将以上代码保存为一个C文件,然后编译运行。在程序运行时,首先输入一组数据作为二叉排序树结点(以-1作为结束),然后输入要查找的。程序会输出是否找到该。最后,记得释放二叉排序树的内存。 希望对你有帮助!如果有更多问题,请继续提问。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值