news 2025/12/25 16:00:22

LC.783 | 二叉搜索树节点最小距离 | 树 | 中序遍历有序性

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LC.783 | 二叉搜索树节点最小距离 | 树 | 中序遍历有序性

输入:二叉搜索树的根节点root

要求:计算树中任意两个不同节点值之间的最小差值。

输出:一个整数,表示最小差值。


思路:

这道题如果是一棵普通的二叉树,我们需要把所有节点值存下来,两两比较,复杂度是 O(N^2)。但因为它是二叉搜索树 (BST),我们可以利用其特性将问题极大简化。

  1. 核心转化:BST -> 有序数组
    • 二叉搜索树的中序遍历结果是一个单调递增的有序数组
    • 在一个有序数组中,最小的差值一定出现在相邻的两个数之间
    • 例如:[1, 4, 7, 9]。差值只可能产生在4-1,7-4,9-7之间,绝对不可能产生在9-1之间。
  2. 优化空间:双指针思维
    • 我们不需要真的开辟一个数组把所有数存下来(那样空间复杂度是 O(N))。
    • 我们在遍历过程中,只需要知道“上一个遍历到的节点值” (lastprev)是多少。
    • 当前节点值root->val减去上一个节点值last,就是当前的相邻差值。我们不断更新这个差值的最小值即可。
  3. 处理细节:
    • 我们需要一个变量last来记录上一个节点的值。初始化为-1(或者一个不可能的负数),表示这是第一个节点,还没上家,不计算差值。

复杂度:

  • 时间复杂度:O(N)
    • 需要中序遍历整棵树。
  • 空间复杂度:O(H)
    • H 为树的高度,主要是递归栈的空间。

class Solution { public: void inorder(TreeNode* root, int& ans, int& last) { if (!root) { return; } // 1. 递归左子树 inorder(root->left, ans, last); // 2. 处理当前节点(中序位置) if (last == -1) { // 如果是第一个节点,只需更新 last,没法计算差值 last = root->val; } else { // 计算当前节点与上一个节点的差值,并更新最小值 // 因为是中序遍历,root->val 一定大于 last,所以不用 abs 也行 ans = min(abs(root->val - last), ans); // 更新 last 为当前节点,供下一次使用 last = root->val; } // 3. 递归右子树 inorder(root->right, ans, last); } int minDiffInBST(TreeNode* root) { int ans = INT_MAX; int last = -1; // 用于记录中序遍历中的“上一个”节点值 inorder(root, ans, last); return ans; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/16 19:41:18

从数据到决策:用R语言完成金融机构流动性风险全景分析

第一章:Shell脚本的基本语法和命令Shell脚本是Linux/Unix系统中自动化任务的核心工具,通过编写可执行的文本文件,用户能够批量执行命令、控制程序流程并处理数据。它运行在命令行解释器(如bash)中,具备变量…

作者头像 李华
网站建设 2025/12/16 19:40:21

重排序效果上不去?从Dify日志中找出被隐藏的性能黑洞

第一章:重排序效果上不去?从Dify日志中找出被隐藏的性能黑洞在构建基于检索增强生成(RAG)的应用时,重排序(Re-ranking)是提升结果相关性的关键环节。然而,即便集成了先进的重排序模型…

作者头像 李华
网站建设 2025/12/16 19:39:18

腾讯云国际站代理商的TAPD如何帮助企业进行成本控制?

腾讯云国际站代理商的 TAPD 主要通过工具自身的功能特性,搭配代理商的专属价格优惠、定制化服务与运维支持,从直接采购成本、研发管理成本、隐性运维成本三个维度帮助企业实现成本控制,具体如下:压缩直接采购成本,减少…

作者头像 李华
网站建设 2025/12/16 19:38:45

Dify与Spring AI部署难题全解析,掌握这7招就能稳上生产环境

第一章:Dify与Spring AI集成概述将 Dify 的低代码 AI 应用开发能力与 Spring AI 框架的灵活性相结合,为 Java 生态构建智能应用提供了全新路径。该集成方案允许开发者在 Spring Boot 项目中无缝调用由 Dify 驱动的 AI 工作流,实现自然语言处理…

作者头像 李华
网站建设 2025/12/16 19:38:05

保险综合处理平台源码 Java+SpringBoot+Vue3

一、关键词 保险综合业务处理平台,保险综合运营处理平台,保险综合业务系统二、作品包含 源码数据库全套环境和工具资源本地部署教程三、项目技术 前端技术:Html、Css、Js、Vue3.0、Element-plus 后端技术:Java、SpringBoot2.0、My…

作者头像 李华