【C/C++】BST树的后序遍历

题目描述:

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

参考以下这颗二叉搜索树:

5

/ \

2 6

/ \

1 3

示例 1:

输入: [1,6,3,2,5]

输出: false

示例 2:

输入: [1,3,2,6,5]

输出: true

cpp 复制代码
#include <iostream>
#include <vector>
using namespace std;

class Solution {
public:
    // 入口函数,判断输入的整数数组是否是某二叉搜索树的后序遍历结果
    bool verifyPostorder(vector<int>& postorder) {
        // 调用辅助函数 verifyPostorderHelper,传入整数数组、数组起始位置和结束位置
        return verifyPostorderHelper(postorder, 0, postorder.size() - 1);
    }
    
    // 辅助函数,用于递归检查数组是否满足二叉搜索树的后序遍历结果
    bool verifyPostorderHelper(vector<int>& postorder, int start, int end) {
        // 当起始位置大于等于结束位置时,表示只有一个节点或者空树,必然满足条件,返回 true
        if (start >= end) return true;
        
        // 获取根节点的值,根节点位于数组末尾
        int root = postorder[end];
        
        int i = start;
        // 在数组中找到左子树的区间,左子树的所有节点值都小于根节点
        while (postorder[i] < root) ++i;
        
        int j = i;
        // 在数组中找到右子树的区间,右子树的所有节点值都大于根节点
        while (postorder[j] > root) ++j;
        
        // 如果 j 不等于 end,说明右子树部分有小于根节点的值,不符合二叉搜索树的性质,返回 false
        if (j != end) return false;
        
        // 递归检查左右子树是否都满足二叉搜索树的后序遍历结果
        // 左子树的区间为 [start, i-1],右子树的区间为 [i, end-1]
        return verifyPostorderHelper(postorder, start, i - 1) && verifyPostorderHelper(postorder, i, end - 1);
    }
};

int main() {
    // 示例输入数据
    vector<int> postorder1 = {1, 6, 3, 2, 5};
    Solution sol;
    
    // 输出第一个示例的结果
    cout << "Example 1: " << boolalpha << sol.verifyPostorder(postorder1) << endl; // 输出 false
    
    // 示例输入数据
    vector<int> postorder2 = {1, 3, 2, 6, 5};
    
    // 输出第二个示例的结果
    cout << "Example 2: " << boolalpha << sol.verifyPostorder(postorder2) << endl; // 输出 true
    
    return 0;
}
相关推荐
汽车仪器仪表相关领域1 分钟前
经典指针+瞬态追踪:MTX-A模拟废气温度(EGT)计 改装/赛车/柴油车排气温度监测实战全解
大数据·功能测试·算法·机器学习·可用性测试
如果你想拥有什么先让自己配得上拥有8 分钟前
斐波那契黄金分割自然界演化以及金融上的共振?
算法·金融
灰色小旋风11 分钟前
力扣第1题:两数之和(C++)
c++·算法
民乐团扒谱机13 分钟前
机器学习 第二弹 和AI斗智斗勇 机器学习核心知识点全解析(GBDT/XGBoost/LightGBM/随机森林+调参方法)
算法·决策树·机器学习
智驱力人工智能16 分钟前
实线变道检测 高架道路安全治理的工程化实践 隧道压实线监测方案 城市快速路压实线实时预警 压实线与车牌识别联动方案
人工智能·opencv·算法·安全·yolo·边缘计算
We་ct20 分钟前
LeetCode 3. 无重复字符的最长子串:滑动窗口最优解演进与解析
前端·算法·leetcode·typescript
沉默-_-20 分钟前
备战蓝桥杯--栈
数据结构·算法·力扣·
weixin1997010801621 分钟前
B2Bitem_get - 获取商标详情接口对接全攻略:从入门到精通
java·大数据·算法
棱镜Coding33 分钟前
LeetCode-Hot100 31.K个一组反转链表
算法·leetcode·链表
Hello World . .41 分钟前
数据结构:数据结构基础、顺序表、链表
c语言·数据结构·vim