• 数据结构-二叉搜索树的后序遍历序列


    题目:输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则返回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;
    }
  • 相关阅读:
    Flutter
    Flutter
    项目冲刺——第二天
    练习三:用例图
    项目冲刺——第一天
    作业六:团队项目冲刺前期准备
    作业四:软件案例分析
    作业五:需求规格说明书
    【非作业部分】队内暂时安排
    第二次练习——团队展示
  • 原文地址:https://www.cnblogs.com/wn19910213/p/3738951.html
Copyright © 2020-2023  润新知