今日算法: 二叉搜索树

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

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;
    }
};
相关推荐
蝈理塘(/_\)大怨种1 小时前
快速排序的递归与非递归实现
数据结构·算法
吴可可1231 小时前
用Bulge保持多段线圆弧连续性
算法·c#
qq_296553271 小时前
矩阵逆时针旋转90度:三种解法从入门到精通
数据结构·python·算法·面试·矩阵
声声codeGrandMaster1 小时前
seq2seq概念和数据集处理
人工智能·pytorch·python·算法·ai
谙弆悕博士1 小时前
【附C源码】C语言实现散列表
c语言·开发语言·数据结构·算法·散列表·数据结构与算法
kkeeper~1 小时前
0基础C语言积跬步之深入理解指针(5上)
c语言·开发语言·算法
a1117761 小时前
边缘设备3DGS-SLAM算法对比实验报告
算法·3d
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题 第54题】【JVM篇】第14题:什么是可达性分析算法?
java·jvm·算法·面试
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题 第55题】【JVM篇】第15题:JVM有哪些垃圾收集算法?
java·jvm·算法·面试