[LC]530题 二叉搜索树的最小绝对差

①题目

给定一个所有节点为非负值的二叉搜索树,求树中任意两节点的差的绝对值的最小值。

示例 :

输入:

1
   \
   3
  /
2

输出:
1

解释:
最小绝对差为1,其中 2 和 1 的差的绝对值为 1(或者 2 和 3)。
注意: 树中至少有2个节点。

②思路

这个题我自己没做出来,所以看了别人的题解。

思路就是,使用中序遍历,在中序遍历的同时,计算差值。

③代码

 1 class Solution {
 2     TreeNode pre;
 3     int res = Integer.MAX_VALUE;       //res是一个全局变量,作为答案。它的具体计算,在helper函数里。
 4     public int getMinimumDifference(TreeNode root) {
 5         if(root==null)
 6             return 0;
 7         helper(root);
 8         return res;
 9     }
10     private void helper(TreeNode root){
11         if(root==null)  return;    //只是return(什么都不做了,跳出此轮的helper函数),而不要return一个数。
12         helper(root.left);
13         if(pre!=null)
14             res = Math.min(res,Math.abs(root.val-pre.val));
15         pre=root;
16         helper(root.right);
17     }
18 }
19 //中序遍历的结果是升序输出,所以在中序遍历的过程中,计算差值。

④学到的知识

1、中序遍历的核心代码部分就是,在递归时,先输出root.left.val,再输出root.val,最后输出root.right.val。

2、求两者中小的那个,就用Math.min(a,b)函数就行了,不要写什么if(a<b) return a;else return b;行数又多又不好看。

3、注意代码里的15行,也就是root什么时候传给pre。

4、从第10行到12行,就直接可以递归到该BST的左下角那个节点,

5、大概推一下BST左下角的递归流程:

马上要上课了,不跟这个旋转了90的图斗争了。

原文地址:https://www.cnblogs.com/zf007/p/11637104.html

时间: 2024-10-08 15:44:20

[LC]530题 二叉搜索树的最小绝对差的相关文章

[LeetCode] Lowest Common Ancestor of a Binary Search Tree 二叉搜索树的最小共同父节点

Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BST. According to the definition of LCA on Wikipedia: “The lowest common ancestor is defined between two nodes v and w as the lowest node in T that has

PAT树_层序遍历叶节点、中序建树后序输出、AVL树的根、二叉树路径存在性判定、奇妙的完全二叉搜索树、最小堆路径、文件路由

<pre class="code"><span style="font-family: %value; font-size: 14px;">03-树1. List Leaves (25) Given a tree, you are supposed to list all the leaves in the order of top down, and left to right. Input Specification: Each inpu

刷题--二叉搜索树与双向链表

[题目描述] 基础:输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表. 进阶:要求不能创建任何新的节点,只能调整书中节点指针的指向 [基础] 解1:先序遍历二叉树,将遍历结果存入一个队列,再建立双向链表. 1 /** 2 public class TreeNode { 3 int val = 0; 4 TreeNode left = null; 5 TreeNode right = null; 6 7 public TreeNode(int val) { 8 this.val = va

【leetcode 简单】 第六十八题 二叉搜索树的最近公共祖先

给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先. 百度百科中最近公共祖先的定义为:"对于有根树 T 的两个结点 p.q,最近公共祖先表示为一个结点 x,满足 x 是 p.q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)." 例如,给定如下二叉搜索树:  root = [6,2,8,0,4,7,9,null,null,3,5] _______6______ / ___2__ ___8__ / \ / 0 _4 7 9 / 3 5 示例 1: 输入: root

腾讯实习笔试编程题 满二叉搜索树求三个节点的最低公共祖先

题目 对于一棵满二叉搜索树深度为K,节点数为2^k - 1,节点值为[1, 2^k - 1].给出k和任意三个节点的值,输出包含该三个节点的最小子树的根节点值. 输入: 4 10 15 13 输出:12 思路 二分搜索,当搜索到节点x时,若x为三个节点之一或三个节点不在以x为根节点的树的子树的同一侧,则当前节点即为所求.否则二分 代码 1 import java.util.Scanner; 2 3 4 public class Main { 5 6 public static int binar

九度OJ刷题——1009:二叉搜索树

题目描述: 判断两序列是否为同一二叉搜索树序列 输入: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束.接下去一行是一个序列,序列长度小于10,包含(0~9)的数字,没有重复数字,根据这个序列可以构造出一颗二叉搜索树.接下去的n行有n个序列,每个序列格式跟第一个序列一样,请判断这两个序列是否能组成同一颗二叉搜索树. 输出: 如果序列相同则输出YES,否则输出NO 样例输入: 2 567432 543267 576342 0 样例输出: YES NO 这题我的思

每日刷题191130 --基础知识篇 二叉搜索树

休息了两天,状态恢复了一下,补充点基础知识. 二叉搜索树 搜索树数据结构支持许多动态集合操作,包括Search,minimum,maximum,predecessor(前驱),successor(后继),INSERT和DELETE等.因此我们使用一颗搜索树既可以作为一个字典又可以作为一个优先队列.且二叉搜索树上的基本操作所花费的时间与这棵树的高度成正比.二叉搜索树有两个很重要的变体,红黑树与B树,这个我们之后有机会再补一篇文章. 顾名思义,一棵二叉搜索树是以一棵二叉树来组织的.如图所示,这样的一

力扣第95题 不同的二叉搜索树II

力扣第95题 不同的二叉搜索树II 给定一个整数 n,生成所有由 1 ... n 为节点所组成的二叉搜索树. struct TreeNode { int val; TreeNode *left; TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) {} }; vector<TreeNode*> generateTree(int start, int end) { vector<TreeNode*> v

二叉搜索树与双向链表 【第一题】

题目要求:输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向. 解决思路: 1. 根据观察可知,双向链表顺序即为二叉树的中序遍历结果----->采用中序遍历+递归: 2. 中序遍历顺序为:左+中+右,传入一个变量pre. pre可以这样理解:当前结点的pre就是当前结点的前驱.如结点6的前驱是4,结点10的前驱是8.结点4的前驱是NULL. #include <iostream> using namespace std; ty