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

【题目描述】
    输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。
 
【解题思路】
    在后序遍历得到的序列中,最后一个数字是树的根节点的数值。数组中前面的数字可以分为两部分:第一部分是左子树节点的值,它们都比根节点的值小;第二部分是右子树节点的值,它们都比根节点的值大。第一部分和第二部分可以使用递归的方式进行判断。
 
【代码实现】
 1 class Solution {
 2 public:
 3     bool VerifySquenceOfBST(vector<int> sequence) {
 4         if(sequence.empty())
 5             return false;
 6            int root=sequence.back();//后序遍历的最后一个节点为根节点
 7         //在二叉搜索树中左子节点小于根节点,其中i为左右子树的分支点,根据i的值判断左右子树的存在性及其位置
 8         vector<int> leftSeq;
 9         int i;
10         for(i=0;i<sequence.size()-1;++i)
11         {       
12             if(sequence[i]>root)
13                 break;
14             else
15                 leftSeq.push_back(sequence[i]);
16         }
17         //在二叉搜索树种右子节点大于根节点,如果存在小于根节点的数值直接退出
18         vector<int> rightSeq;
19         int j;
20         for(j=i;j<sequence.size()-1;++j)
21         {
22             if(sequence[j]<root)
23                 return false;
24             else
25                 rightSeq.push_back(sequence[j]);
26         }
27 
28         //判断左子树是否是二叉搜索树
29         bool left=true;
30         if(i>0)
31             left=VerifySquenceOfBST(leftSeq);
32 
33         //判断右子树是否是二叉搜索树
34         bool right=true;
35         if(i<sequence.size()-1)
36             right=VerifySquenceOfBST(rightSeq);
37 
38         return (left&&right);
39     }
40 };

 

转载于:https://www.cnblogs.com/lou424/p/5047710.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于这个问题,我们可以使用队列和分治法来求解二搜索的层。具体的实现方法如下: 1. 首先,根据后的定义,可以知道二搜索的根节点是序列的最后一个元素。 2. 然后,使用分治法将序列划分为两个部分,即左子和右子。可以找到第一个比根节点小的元素,将其之前的部分定义为左子的后,之后的部分定义为右子的后。 3. 对于左右子,分别重复上述过程,递归求解左右子的层。 4. 最后,将左右子的层按照层次合并起来,即可得到整棵二搜索的层。 下面是具体的实现代码: ```python def postorder_to_levelorder(postorder): if not postorder: return [] root = postorder[-1] mid = bisect.bisect_left(postorder, root) left_postorder = postorder[:mid] right_postorder = postorder[mid:-1] left_levelorder = postorder_to_levelorder(left_postorder) right_levelorder = postorder_to_levelorder(right_postorder) levelorder = [root] queue = [root] while queue: node = queue.pop(0) if node in left_levelorder: levelorder.extend(left_levelorder[left_levelorder.index(node)+1:]) queue.extend(left_levelorder[left_levelorder.index(node)+1:]) if node in right_levelorder: levelorder.extend(right_levelorder[right_levelorder.index(node)+1:]) queue.extend(right_levelorder[right_levelorder.index(node)+1:]) return levelorder ``` 该实现使用了递归和队列,时间复杂度为 O(nlogn)。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值