首页 > 其他 > 详细

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

时间:2014-05-22 00:36:10      阅读:370      评论:0      收藏:0      [点我收藏+]

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

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

bubuko.com,布布扣
/*
剑指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;
}
bubuko.com,布布扣

 

数据结构-二叉搜索树的后序遍历序列,布布扣,bubuko.com

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

原文:http://www.cnblogs.com/wn19910213/p/3738951.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!