今日算法: 二叉搜索树

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

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;
    }
};
相关推荐
To_OC2 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵5 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC8 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安2 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者2 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent