代码随想录算法训练营第二十一天|LeetCode530 二叉搜索树的最小绝对差、LeetCode501 二叉搜索树中的众数

题1:

指路:LeetCode530 二叉搜索树的最小绝对差
思路与代码:

递归方面我们定义两个指针,一个当前节点指针cur,一个为当前节点的前一个节点pre。中序遍历二叉搜索树,如果当前节点为空则返回。不为空则返回当前节点和上一个节点的差,取较小值。代码如下:

cpp 复制代码
class Solution {
private:
    int result = INT_MAX;
    TreeNode* pre = NULL;
    void traversal(TreeNode* cur) {
        if  (cur == NULL) return ;
        traversal(cur->left);  // 左
        if (pre != NULL) {  // 中
            result = min (result, cur->val - pre->val);
        }    
        pre = cur;
        traversal(cur->right);
    }
public:
    int getMinimumDifference(TreeNode* root) {
    traversal(root);
    return result;
    }
};

题2:

指路:LeetCode501 二叉搜索树中的众数
思路与代码:
cpp 复制代码
class Solution {
private:
    int maxCount = 0; // 最大频率
    int count = 0; // 统计频率
    TreeNode* pre = NULL;
    vector<int> result;
    void searchBST(TreeNode* cur) {
        if (cur == NULL) return ;
        searchBST(cur->left);       // 左
                                    // 中
        if (pre == NULL) { // 第一个节点
            count = 1;
        } else if (pre->val == cur->val) { // 与前一个节点数值相同
            count++;
        } else { // 与前一个节点数值不同
            count = 1;
        }
        pre = cur; // 更新上一个节点
        if (count == maxCount) { // 如果和最大值相同,放进result中
            result.push_back(cur->val);
        }
        if (count > maxCount) { // 如果计数大于最大值频率
            maxCount = count;   // 更新最大频率
            result.clear();     // 很关键的一步,不要忘记清空result,之前result里的元素都失效了
            result.push_back(cur->val);
        }
        searchBST(cur->right);      // 右
        return ;
    }

public:
    vector<int> findMode(TreeNode* root) {
        count = 0;
        maxCount = 0;
        pre = NULL; // 记录前一个节点
        result.clear();
        searchBST(root);
        return result;
    }
};

今天没心情做了,到这就停一下吧。我得放松一下。

相关推荐
handler015 小时前
从源码到二进制:深度拆解 Linux 下 C 程序的编译与链接全流程
linux·c语言·开发语言·c++·笔记·学习
不爱吃炸鸡柳6 小时前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构
t***5446 小时前
如何在Dev-C++中使用Clang编译器
开发语言·c++
Qbw20046 小时前
【Linux】进程地址空间
linux·c++
Aurorar0rua6 小时前
CS50 x 2024 Notes C - 05
java·c语言·数据结构
6Hzlia7 小时前
【Hot 100 刷题计划】 LeetCode 739. 每日温度 | C++ 逆序单调栈
c++·算法·leetcode
良木生香8 小时前
【C++初阶】:STL——String从入门到应用完全指南(1)
c语言·开发语言·数据结构·c++·算法
XWalnut8 小时前
LeetCode刷题 day16
数据结构·算法·leetcode·链表·动态规划
寒秋花开曾相惜8 小时前
(学习笔记)4.1 Y86-64指令集体系结构(4.1.4 Y86-64异常&4.1.5 Y86-64程序)
开发语言·jvm·数据结构·笔记·学习