今日算法: 二叉搜索树

思路:二叉搜索树,已经有序,将树放进数组中,然后进行比较,

cpp 复制代码
class Solution {
public:
vector<int> vec;
void traversal(TreeNode*root)
{
    if(root==nullptr) return;

    traversal(root->left);
    vec.push_back(root->val);
    traversal(root->right);
}
    int getMinimumDifference(TreeNode* root) {
        //用一个vector存有序数组,进行临近比较;
        traversal(root);
        if(vec.size()<2) return 0;
        int result = INT_MAX;
        for(int i=1;i<vec.size();i++)
        {
            result=min(result,vec[i]-vec[i-1]);
        }
        return result;
    }
};

思路:在中序遍历时,我们可以直接进行比较,只不过需要记录前一个节点

cpp 复制代码
class Solution {
public:
int result=INT_MAX;
TreeNode*pre=NULL;
void traversal(TreeNode*root)
{
        if(root==NULL) return;
        traversal(root->left);//左
        if(pre!=nullptr)
        {
            result=min(result,root->val-pre->val);//中
        }
        pre=root;
        traversal(root->right);
}
    int getMinimumDifference(TreeNode* root) {
        //用一个vector存有序数组,进行临近比较;
        traversal(root);
        
        return result;
    }
};

使用迭代法:用栈进行,记住前后的就行

cpp 复制代码
class Solution {
public:

    int getMinimumDifference(TreeNode* root) {
     //使用栈进行遍历
     stack<TreeNode*> st;
     TreeNode*cur=root;
     TreeNode*pre=nullptr;
     int result=INT_MAX;
     while(cur!=nullptr||!st.empty())
     {
        if(cur!=nullptr)//不为空入栈
        {
                st.push(cur);
                cur=cur->left;
        }
        else//为空
        {
            cur=st.top();
            st.pop();
            if(pre!=nullptr)
            {
                result=min(result,cur->val-pre->val);
            }
            pre=cur;
            cur=cur->right;
        }
     }
        
        return result;
    }
};
相关推荐
8Qi823 分钟前
LeetCode 235. 二叉搜索树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·二叉搜索树·lca·迭代
bIo7lyA8v44 分钟前
算法稳定性分析中的随机扰动建模的技术8
算法
科研online1 小时前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy1 小时前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯2 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
VkN2X2X4b2 小时前
算法复杂度的实验验证与误差分析的技术8
算法
其利天下技术2 小时前
风扇灯无刷电机自适应算法实战指南
算法·cocos2d·无刷电机自适应算法·bldc驱动自适应算法·其利无刷电机驱动算法
8Qi82 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
hujinyuan201603 小时前
2026年3月 中国电子学会青少年软件编程(Python)三级考试试卷 真题及答案
java·python·算法
froyoisle3 小时前
CSP-J 历年复赛 T1 及解析(2019~2025)
数据结构·c++·算法·csp-j·csp·算法竞赛·信息学