力扣面试题 33 - 合法二叉搜索树

题目:

实现一个函数,检查一棵二叉树是否为二叉搜索树。

示例 1:

复制代码
输入:
    2
   / \
  1   3
输出:true

示例 2:

复制代码
输入:
    5
   / \
  1   4
     / \
    3   6
输出:false
解释:输入为: [5,1,4,null,null,3,6]。
     根节点的值为 5 ,但是其右子节点值为 4 。

思路:

  1. 首先你需要知道什么是二叉搜索树。CSDN可以自行搜索,这里不赘述。
  2. 二叉搜索树有一个特性,中序遍历二叉搜索树,其得到的序列一定是升序的。
  3. 利用这个特性,我们可以判断该树是否是二叉搜索树。
  4. 先对树进行中序遍历,得到一个数组。
  5. 判断数组是否升序,不是即不为二叉搜索树。

C语言代码如下:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */

/* 中序遍历 */
void InorderTraverse(struct TreeNode* root, int* array, int* index){
    if(root == NULL) return;  // 递归终止条件
    InorderTraverse(root->left, array, index);
    array[(*index)++] = root->val;  // 保存当前节点值,并更新索引
    InorderTraverse(root->right, array, index);
}

/* 判断是否升序 */
bool isAscend(int* array, int length){
    for(int i = 1; i < length; i++){
        if(array[i] <= array[i - 1]) return false;  // 升序判断
    }
    return true;
}

bool isValidBST(struct TreeNode* root) {
    if(root == NULL) return true;  // 空树也是有效的BST
    
    // 假设树的节点数不会超过10000
    int* array = (int*)malloc(10000 * sizeof(int));
    if(array == NULL) return false;  // 检查内存分配失败
    
    int index = 0;  // 中序遍历的索引
    InorderTraverse(root, array, &index);  // 获取中序遍历的结果
    
    bool result = isAscend(array, index);  // 检查中序遍历是否为升序
    free(array);  // 释放动态分配的内存
    return result;
}

时间复杂度、空间复杂度均为O(N)。

相关推荐
不穿格子的程序员3 分钟前
从零开始写算法——图论篇2:课程表 + 实现前缀树(26叉树)
算法·深度优先·图论·dfs·bfs
啊阿狸不会拉杆5 分钟前
《数字信号处理》第5章-数字滤波器的基本结构
python·算法·机器学习·matlab·信号处理·数字信号处理·dsp
AI 菌5 分钟前
视觉令牌压缩:Vision-centric Token Compression in Large Language Model
人工智能·算法·语言模型·llm
Fleshy数模7 分钟前
从原理到实战:逻辑回归,机器学习的“Hello World”
算法·机器学习·逻辑回归
XH华8 分钟前
备战蓝桥杯,第五章:string字符串
c++·职场和发展·蓝桥杯
少许极端11 分钟前
算法奇妙屋(二十六)-二叉树的深度搜索问题
算法·二叉树·dfs
2401_8414956411 分钟前
【LeetCode刷题】二叉树的中序遍历
数据结构·python·算法·leetcode··递归·遍历
pcm12356712 分钟前
设计C/S架构的IM通信软件(2)
java·c语言·架构
2301_8174973313 分钟前
C++中的适配器模式实战
开发语言·c++·算法
砚边数影14 分钟前
逻辑回归实战(一):用户流失预测数据集设计,KingbaseES存储标签数据
java·人工智能·算法·机器学习·逻辑回归·线性回归·金仓数据库