zoukankan      html  css  js  c++  java
  • 二叉搜索树的后序遍历序列

    题目:输入一个整数数组,判断该数组是不是某二叉树的后序遍历的结果.如果是则返回true,否则返回false.假设输入的数组的任意两个数字互不相同.
    例如输入数组{5,7,6,9,11,10,8},则返回true,因为这个整数序列是下图二叉树的后序遍历的结果.如果输入的数组是{7,4,6,5},由于没有哪棵二叉搜索树的后序遍历的结果是这个序列,因此返回false.
    后序遍历序列5、7、6、9、11、10、8对应的二叉搜索树
    在后序遍历得到的序列中,最后一个数字是根结点的值.数组中前面的数字可以分为两部分:第一部分是左子树结点的值,他们都比根结点的值小;第二部分是右节点的值,他们都比根结点的值大.
    以数组{5,7,6,9,11,10,8}为例,后序遍历的结果的最后一个数字8就是根结点的值.在这个数组中,前3个数字5,7和6都比8小,是值为8的结点的左子树结点;后3个数字9,11,10都比8大,是值为8的结点的右子树结点.
    我们接下来用同样的方法确定与数组每一部分对应子树的结构.这其实就是一个递归的过程.对于序列5,7,6,最后一个数字6是左结点的根结点的值.数字5比6小,是值为6结点的左子结点,而7是它的右子节点.同样,在序列9,11,10中,最后一个数字10是右子树的根结点,数字9比10小,是值为10的结点的左子结点,而11则是它的右子节点.
    我们再来分析另一个整数数组{7,4,6,5}.后序遍历的最后一个数是根结点,因此在对应的二叉搜索树中,根结点上是没有左子树的,数字7,4,6都是右子树结点的值.但我们发现在右子树有一个结点的值是4,比根结点的值5小,这就违背了二叉搜索树的定义.因此不存在一棵二叉树,它的后序遍历的结果是7,4,6,5.
     
    找到规律后再写代码,就不是一件很困难的事情了.下面是参考代码:
     1 bool VerifySquenceOfBST(int sequence[],int length)
     2 
     3 {
     4 
     5  if(sequence==NULL||length<=0)
     6 
     7  return false;
     8 
     9  int root=sequence[length-1];
    10 
    11  
    12 
    13  //在二叉搜索树中左子树的结点小于根结点
    14 
    15  int i=0;
    16 
    17  for(;i<length-1;++i)
    18 
    19  {
    20 
    21   if(sequence[i]>root)
    22 
    23   break;
    24 
    25   }
    26 
    27  
    28 
    29  //在二叉搜索树中右子树的结点大于根结点
    30 
    31  int j=i;
    32 
    33  for(;j<length-1;++j)
    34 
    35  {
    36 
    37   if(sequence[j]<root)
    38 
    39   return false;
    40 
    41 }
    42 
    43  
    44 
    45 //判断左子树是不是二叉搜索树
    46 
    47 bool left=true;
    48 
    49 if(i>0)
    50 
    51 left=VerifySquenceOfBST(sequence,i);
    52 
    53  
    54 
    55 //判断右子树是不是二叉搜索树
    56 
    57 bool right=true;
    58 
    59 if(i<length-1)
    60 
    61  right=VerifySequenceOfBST(sequence+i,length-i-1);
    62 
    63  
    64 
    65 return (left&&right);
    66 
    67 }
     
  • 相关阅读:
    协同过滤算法
    redis雪崩,击穿,穿透
    scentos7安装redis,以及redis的主从配置
    centos7安装python3
    vm虚拟机安装centos7。克隆镜像以及快照
    全文检索django-haystack+jieba+whoosh
    drf的权限扩充
    redis分布式锁解决超卖问题
    Django结合Websocket进行WebSSH的实现
    vue-父子组件传参以及无限级评论
  • 原文地址:https://www.cnblogs.com/wxdjss/p/5451955.html
Copyright © 2011-2022 走看看