news 2026/4/16 15:19:26

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/4/10 20:30:19

【Qt开源项目】— ModbusScope-进度规划

ModbusScope学习总进度与时间规划 根据我们之前的讨论和你的学习进度&#xff0c;我来为你制定一个完整的学习计划。 当前进度总结 你已经完成的学习内容&#xff08;按时间顺序&#xff09;&#xff1a; ✅ 第一阶段&#xff08;3天&#xff09;&#xff1a;整体认知、程序骨架…

作者头像 李华
网站建设 2026/4/16 12:42:49

AutoGPT如何制定营销推广计划?实战案例拆解

AutoGPT如何制定营销推广计划&#xff1f;实战案例拆解 在一家新茶饮品牌即将推出“樱花白桃冰”新品的会议室里&#xff0c;市场团队正为推广方案焦头烂额&#xff1a;用户画像不清晰、竞品动作难追踪、内容创意枯竭……如果能有一个助手&#xff0c;只需一句话就能自动生成完…

作者头像 李华
网站建设 2026/4/16 12:32:15

测试用例设计方法:正交试验法详解!

01 正交试验法介绍 正交试验法是研究多因素、多水平的一种试验法&#xff0c;它是利用正交表来对试验进行设计&#xff0c;通过少数的试验替代全面试验&#xff0c;根据正交表的正交性从全面试验中挑选适量的、有代表性的点进行试验&#xff0c;这些有代表性的点具备了“均匀分…

作者头像 李华