【Java】 剑指offer(33) 二叉搜索树的后序遍历序列

本文参考自《剑指offer》一书,代码采用Java语言。

更多:《剑指Offer》Java实现合集  

题目 

  输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则返回true,否则返回false。假设输入的数组的任意两个数字都互不相同。

思路

  二叉树后序遍历数组的最后一个数为根结点,剩余数字中,小于根结点的数字(即左子树部分)都排在前面,大于根结点的数字(即右子树部分)都排在后面。根据遍历数组的这个特性,可以编写出一个递归函数,用于实现题目所要求的判断功能。

测试算例 

  1.功能测试(左斜树;右斜树;能对应的二叉树;不能对应的二叉树序列)

  2.特殊测试(null;一个结点)

Java代码

//题目:输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。
//如果是则返回true,否则返回false。假设输入的数组的任意两个数字都互不相同。

public class SquenceOfBST {
	public boolean  verifySquenceOfBST(int[] sequence) {
		if(sequence== null || sequence.length<=0)
			return false;
		return verifyCore(sequence, 0, sequence.length-1);
	}

	private boolean verifyCore(int[] sequence,int start,int end) {
		if(start>=end)
			return true;
		//判断左子树
		int mid=start;
		while(sequence[mid]<sequence[end])
			mid++;
		//判断右子树
		for(int i=mid;i<end;i++) {
			if(sequence[i]<sequence[end])
				return false;
		}
		return verifyCore(sequence, start, mid-1)&&verifyCore(sequence, mid, end-1);
	}
}

  

收获

  1.寻找出序列规律,就能较快得到思路。此题如果改为BST的前序遍历也是相同的思路。

  2.对于要求处理二叉树序列的问题:找到根结点后,拆分出左右子树,对左右子树可以进行递归处理。

  3.虽然有了思路,但自己在编写代码的时候还是写得比较乱,花了一些时间才能修改出比较简洁和清晰易懂的版本,说明自己写的代码量还是不够,要继续多加练习。

更多:《剑指Offer》Java实现合集  

  

原文地址:https://www.cnblogs.com/yongh/p/9819233.html

时间: 2024-07-29 19:08:01

【Java】 剑指offer(33) 二叉搜索树的后序遍历序列的相关文章

[剑指offer] 判断二叉搜索树的后序遍历序列

题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 输入描述 整数数组 输出描述 布尔值 题目分析 什么是二叉搜索树? 二叉查找树(Binary Search Tree),(又:二叉搜索树,二叉排序树)它或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值: 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值: 它的左.右子树也分别为二

剑指Offer之二叉搜索树的后序遍历序列

题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 基本思路 在后序遍历得到的序列中,最后一个数字是树的根节点的值.数组中前面的数字可以分为两部分:第一部分是左子树节点的值,它们都比根节点的值小:第二部分是右子树节点的值,他们都比根节点的值大. 以数组{5,7,6,9,10,8}为例,后序遍历结果的最后一个数字8就是根节点的值.在这个数组中,前3个数字5,7和6都比8小,是值为8的节点的左子树节点:

【剑指Offer】二叉搜索树的后序遍历序列

问题描述: 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 背景知识: 二叉搜索树(Binary Search Tree),又叫二叉排序树:或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值: 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值: 它的左.右子树也分别为二叉排序树. 算法描述: 将数列分为三段,最后一段是最后一个数,也是树的

剑指Offer 23. 二叉搜索树的后序遍历序列 (二叉搜索树)

题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 题目地址 https://www.nowcoder.com/practice/a861533d45854474ac791d90e447bafd?tpId=13&tqId=11176&rp=2&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

剑指offer:二叉搜索树的后序遍历序列

题目描述输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. class Solution: """ 一个二叉搜索树BST满足: max(左子树) < 根节点 < min(右子树) 由于题目给出的是一个后序遍历,那么序列的最后一个元素就应该是根节点. 因此我们从BST的定义出发,遍历整个序列,找到第一个大于根节点的元素k,k以前的元素属于左子树, 从k开始到根节点之前的元素属于右

[剑指Offer] 23.二叉搜索树的后序遍历

[思路]BST的后序序列的合法序列是,对于一个序列S,最后一个元素是x (也就是根),如果去掉最后一个元素的序列为T,那么T满足:T可以分成两段,前一段(左子树)小于x,后一段(右子树)大于x,且这两段(子树)都是合法的后序序列.下面是在讨论中看到的一份代码,已学习到. 1 class Solution { 2 public: 3 bool VerifySquenceOfBST(vector<int> sequence) { 4 int size = sequence.size(); 5 if

33. 二叉搜索树的后序遍历序列

题目:输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历结果.如果是则返回 true,否则返回 false.假设输入的数组的任意两个数字都互不相同. 思路步骤: 1.确定根节点root:2.遍历序列(除去root结点),找到第一个大于root的位置,则该位置左边为左子树,右边为右子树:3.遍历右子树,若发现有小于root的值,则直接返回false:4.分别判断左子树和右子树是否仍是二叉搜索树(即递归步骤1.2.3). class Solution: def verifyPostorder(

剑指Offer对答如流系列 - 二叉搜索树的后序遍历序列

面试题33:二叉搜索树的后序遍历序列 题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则返回true,否则返回false.假设输入的数组的任意两个数字都互不相同. 例如,输入数组{5.7.6.9.11.10.8},则返回true,因为这个整数序列是下图二叉搜索树的后序遍历结果. 如果输入的数组是{7.4.6.5},则由于没有哪棵二叉搜索树的后序遍历是这个序列,因此返回false. 问题分析 后序遍历 遍历顺序是 :左子树 -> 右子树 -> 根结点(最后遍历根节

二叉搜索树的后序遍历序列-剑指Offer

二叉搜索树的后序遍历序列 题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 思路 后序遍历:左-->右-->根节点 二叉搜索树中,左子树的节点小于根节点,右子树的节点大于根节点 递归调用,根据大小区别左右子树,若在右子树中发现小于根节点的节点,就不是后续遍历序列 举一反三:如果要求处理一棵二叉树的遍历序列,我们可以先找到二叉树的根节点,再基于根节点把整棵树的遍历序列拆分成左子树对应的子序列和右子