zoukankan      html  css  js  c++  java
  • 数据结构-二叉搜索树的后序遍历序列

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

    分析:由后序遍历可以知道最后一个数字是树的根节点,而二叉搜索树的性质可以知道其左边的节点值小于根节点的值,右边的节点值大于根节点的值。由此递归。

    /*
    剑指offer面试题24
    */
    #include <iostream>
    
    using namespace std;
    
    bool IsPostTree(int* a,int length){
        if(length <= 0){
            return false;
        }
    
        int root = *(a+length-1);
    
        int i=0;
        for(;i<length-1;i++){
            if(a[i] > root){
                break;
            }
        }
    
        int j=0;
        for(j=i;j<length-1;j++){
            if(a[j] < root){
                return false;
            }
        }
    
        bool left = true;
        if(i>0){
            left = IsPostTree(a,i);
        }
    
        bool right = true;
        if(j<length-1){
            right = IsPostTree(a+i,length-i-1);
        }
    
        return (left && right);
    }
    
    int main()
    {
        int length,n;
    
        cin >> length;
    
        int a[length];
    
        if(length > 0){
            for(int i=0;i<length;i++){
                cin >> n;
                a[i] = n;
            }
        }
    
        bool result = IsPostTree(a,length);
    
        cout << result;
    
        return 0;
    }
  • 相关阅读:
    favicon.ico请求处理
    Node.js学习(Node.js基础)
    实现主机访问虚拟机网页的方法总结
    有向/无向图中搜环
    后缀自动机
    莫队算法
    A* 算法求第k短路径
    次小生成树算法
    AC自动机详解
    Link-Cut-Tree详解
  • 原文地址:https://www.cnblogs.com/wn19910213/p/3738951.html
Copyright © 2011-2022 走看看