首页IT科技二叉搜索树的后序遍历(每日算法之二叉搜索树的后序遍历序列)

二叉搜索树的后序遍历(每日算法之二叉搜索树的后序遍历序列)

时间2025-06-20 11:21:32分类IT科技浏览4212
导读:JZ33 二叉搜索树的后序遍历序列 描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则返回...

JZ33 二叉搜索树的后序遍历序列

描述

输入一个整数数组           ,判断该数组是不是某二叉搜索树的后序遍历的结果            。如果是则返回 true ,否则返回 false                 。假设输入的数组的任意两个数字都互不相同      。 提示: 1.二叉搜索树是指父亲节点大于左子树中的全部节点                  ,但是小于右子树中的全部节点的树         。 2.该题我们约定空树不是二叉搜索树 3.后序遍历是指按照 “左子树-右子树-根节点            ” 的顺序遍历

思路

BST的后序序列的合法序列是      ,对于一个序列S        ,最后一个元素是x (也就是根)                  ,如果去掉最后一个元素的序列为T         , 那么T满足:T可以分成两段     ,前一段(左子树)小于x                  ,后一段(右子树)大于x            , 且这两段(子树)都是合法的后序序列                 。完美的递归定义

代码

package mid.JZ33二叉搜索树的后序遍历序列; public class Solution { public boolean VerifySquenceOfBST(int [] sequence) { if (sequence == null || sequence.length == 0) return false; return judge(sequence, 0, sequence.length - 1); } public boolean judge(int[] sequence, int start, int end) { //为空 if (start >= end) return true; //根节点 int root = sequence[end]; int i = start; //左子树遍历 while (i <= end && sequence[i] < root) { i++; } //右子树 for (int j = i; j < end; j++) { if (sequence[j] < root) return false; } //左子树 与 右子树递归 /** * i 是右子树第一个元素 * 左侧 start开始  ,i-1结束 * 右侧 i开始                 ,end-1是减去当前根元素 */ return judge(sequence, start, i - 1) && judge(sequence, i, end - 1); } }

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
如何利用phpstudy 2018搭建php网站(phpcms搭建步骤是什么?)