news 2026/5/5 3:04:06

LC.450 | 删除二叉搜索树中的节点 | 树 | 暴力重构/转化思维

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LC.450 | 删除二叉搜索树中的节点 | 树 | 暴力重构/转化思维

输入:
二叉搜索树的根节点root和一个需要删除的值key

要求:
删除 BST 中的指定节点,并保证二叉搜索树性质不变。

输出:
删除后的新树根节点。


思路:

这道题的标准解法通常涉及复杂的指针操作(特别是处理双子节点的情况)。但在实际解题或笔试中,如果我们一时无法理清复杂的指针断连逻辑,可以转换思维,利用“数据结构的特性”来降维打击。
当然这题自然有正规写法,等回头思路清晰了再来写,今天先来个暴力写法开开胃。
本题解采用“暴力重构”策略:
既然在树上直接修补很难,不如利用 BST 的性质:

  1. 拆迁(遍历):二叉搜索树本质上就是一堆有序的数据。我们可以先遍历整棵树,把除了目标key以外的所有节点值都收集到一个数组中。
  2. 重建(构造):拿着这个干净的数组,直接调用“构建二叉搜索树”(参考 LC.1008)的逻辑,重新盖一棵新树。

虽然这种方法在空间和时间上不是最优(涉及大量内存分配),但它逻辑极其简单,不易出错,是一种非常实用的“工程化”解题思路——解决不了问题,就解决提出问题的人(节点),然后重新组队。


复杂度:

  • 时间复杂度:O(N)O(N)O(N)
    • 遍历收集节点需要O(N)O(N)O(N),重新构建树也需要O(N)O(N)O(N)。虽然常数项较大,但量级依然是线性的。
  • 空间复杂度:O(N)O(N)O(N)
    • 需要一个数组来存储所有节点的值,加上递归栈的空间。

#include<iostream>#include<vector>#include<algorithm>usingnamespacestd;structTreeNode{intval;TreeNode*left;TreeNode*right;TreeNode():val(0),left(nullptr),right(nullptr){}TreeNode(intx):val(x),left(nullptr),right(nullptr){}TreeNode(intx,TreeNode*left,TreeNode*right):val(x),left(left),right(right){}};classSolution{public:TreeNode*deleteNode(TreeNode*root,intkey){vector<int>vals;preorder(root,vals,key);returnbuildTree(vals);}voidpreorder(TreeNode*root,vector<int>&vals,intkey){if(!root)return;if(root->val!=key){vals.push_back(root->val);}preorder(root->left,vals,key);preorder(root->right,vals,key);}// 照搬 LC.1008 的逻辑TreeNode*buildTree(vector<int>&pre){if(pre.size()==0)returnnullptr;TreeNode*root=newTreeNode(pre[0]);vector<int>leftPart,rightPart;for(inti=1;i<pre.size();i++){if(pre[i]<pre[0])leftPart.push_back(pre[i]);elserightPart.push_back(pre[i]);}root->left=buildTree(leftPart);root->right=buildTree(rightPart);returnroot;}};
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 15:00:29

OpenSpec定义AI模型接口标准助力Qwen3-VL-30B集成

OpenSpec定义AI模型接口标准助力Qwen3-VL-30B集成 在当今AI系统日益复杂的背景下&#xff0c;一个尖锐的现实摆在开发者面前&#xff1a;我们拥有越来越强大的模型&#xff0c;却越来越难把它们用起来。 以Qwen3-VL-30B为例——这款300亿参数的视觉语言大模型&#xff0c;能在毫…

作者头像 李华
网站建设 2026/5/2 13:04:35

英伟达B200:AI算力革命的新纪元引擎

英伟达B200&#xff1a;AI算力革命的新纪元引擎在人工智能算力竞赛进入白热化的2024年&#xff0c;英伟达B200 GPU的横空出世&#xff0c;不仅重新定义了数据中心的计算边界&#xff0c;更标志着通用计算架构向智能化跃迁的关键拐点。这款基于Blackwell架构的新一代旗舰产品&am…

作者头像 李华
网站建设 2026/5/4 14:02:13

自动批量混剪视频软件配置流程

这是一款可以自动批量混剪视频的软件&#xff0c;先来看一段通过软件批量增加了动态特效以及边框后的视频效果。 &#x1f4cc; **需要查看完整文档、参数详解与示例配置的朋友&#xff0c;可参考我整理的笔记&#xff1a; ** &#x1f449; xk.xunbk.com 现在各个平台对于视…

作者头像 李华
网站建设 2026/5/4 22:58:17

多系统并行的权限治理难题:如何消除“权限孤岛”与安全风险?

在企业数字化转型浪潮中&#xff0c;数据被视为新的生产资料&#xff0c;其安全与合规性成为企业的生命线。然而&#xff0c;许多企业将安全投入的焦点放在了防火墙、入侵检测、加密技术等“外围防御”上&#xff0c;却往往忽略了内部数据安全的“命门”——权限管理&#xff0…

作者头像 李华