首页 > 其他分享 >(20/60)二叉搜索树的最小绝对差、二叉搜索树中的众数、二叉树的最近公共祖先

(20/60)二叉搜索树的最小绝对差、二叉搜索树中的众数、二叉树的最近公共祖先

时间:2024-02-19 20:35:24浏览次数:27  
标签:node right TreeNode val int 二叉 搜索 二叉树 left

过外婆八十寿宴,补卡

二叉搜索树的最小绝对差

leetcode:530. 二叉搜索树的最小绝对差

双指针中序遍历法

思路

搜索树的最小绝对差一定出现在中序遍历的相邻两个元素之间。

设置前后两个指针,每次对比“历史最小”与当前node->val - pre->val的值哪个更小,进行相应更新。

复杂度分析

时间复杂度:O(N)。遍历一遍。

空间复杂度:递归栈深度,树的深度。近完全时O(logN),近链表时O(N)。

注意点

  1. pre = node是一定要执行的,不要写到else里了

代码实现

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    TreeNode* pre;
    int result = INT32_MAX;
    void traversal(TreeNode* node){
        // 空节点结束
        if(node == NULL) return;
        // 中序遍历
        traversal(node->left);
        if(pre) result = min(result,node->val - pre->val);            
        pre = node; // 这句一定要执行,不要写到else里了
        traversal(node->right);
    }
    int getMinimumDifference(TreeNode* root) {
        traversal(root);
        return result;
    }
};

二叉搜索树中的众数

leetcode:501. 二叉搜索树中的众数

递归遍历通法

思路

遍历整棵树,建立map映射,value最大的为众数。

复杂度分析

时间复杂度:O(N)。但是三个并列的O(N)级别。

空间复杂度:递归栈深度,最好O(logN),最差O(N)。

注意点

  1. map的元素类型是pair<T,T>。

代码实现

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    // 中序遍历,map映射
    unordered_map<int,int> map;
    void traversal(TreeNode* node){
        // 空节点终止
        if(node == NULL) return;
        traversal(node->left);
        map[node->val]++;
        traversal(node->right);
    }
    vector<int> findMode(TreeNode* root) {
        traversal(root);
        // 找最大频数
        int mostFreq = 0;
        for(pair<int,int> p : map){
            mostFreq = max(mostFreq,p.second);
        }
        // 根据最大频数找众数
        vector<int> vec;
        for(pair<int,int> p : map){
            if(p.second == mostFreq) vec.push_back(p.first);
        } 
        return vec;
    }
};

Carl的做法是把map转化为vector,然后再排序、取首或末的那些元素(取决于排序规则)。

搜索树中序遍历法

思路

搜索树,中序遍历下众数一定是连续出现的,只需要一个count变量计数即可。

复杂度分析

时间复杂度:O(N)。遍历一遍。

空间复杂度:递归栈深度,最好O(logN),最差O(N)。

注意点

  1. count、maxCount要初始化为1,否则第一个节点会无法正常置入result。

    (因为在第二个节点时,若前后节点不等,count会置为1而maxCount默认值为0,再往下会count > maxCount,清空result里存放的第一个节点)

代码实现

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    // 一次中序遍历
    // 注意这两个变量都必须初始化为1
    int count = 1;	
    int maxCount = 1;
    TreeNode* pre;
    vector<int> result;
    void traversal(TreeNode* cur){
        // 终止条件是空节点
        if(cur == NULL) return;
        // 中序遍历
        traversal(cur->left);
        // 中
        // 根据值处理count
        if(pre){
            if(pre->val == cur->val) count++; // 和前一个值相等,count++
            else count = 1; // 值不等时归1
        }
        // 根据count找众数
        if(count >= maxCount){  // count>=maxCount的时候都放入结果数组
            // 如果count>maxCount就更新maxCount和result数组(清空)
            if(count > maxCount){
                maxCount = count;
                result.clear();
            }
            result.push_back(cur->val);
        }
        pre = cur;  // 前指针后移
        // 右
        traversal(cur->right);
    }
    vector<int> findMode(TreeNode* root) {
        traversal(root);
        return result;
    }
};

二叉树的最近公共祖先

leetcode:236. 二叉树的最近公共祖先

思路

node->val互异且p、q都存在。

要找公共祖先需要自底向上遍历,因此选择后序遍历,在向上回溯过程中进行操作。

  1. 如果是p、q,则直接向上返回当前节点(涵盖了第二种情况);是空节点也返回当前节点(NULL)。
  2. 设立两个节点接收左、右递归结果。都空表示没有找到p、q,返回NULL;一侧非空表示找到了p或q,返回非空的那个节点;如果都不空则说明p、q都找到了,当前节点就是最近公共祖先,返回。

复杂度分析

时间复杂度:O(N)。

空间复杂度:递归栈深度,树的高度。树近完全时候O(logN),倾斜时O(N)。

注意点

代码实现

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        // 为空时返回NULL;为p或q时返回自身
        if(!root || root == p || root == q) return root;    
        
        TreeNode* left = lowestCommonAncestor(root->left,p,q);
        TreeNode* right = lowestCommonAncestor(root->right,p,q);

        if(!left && !right) return NULL;	// 左右都为空,向上也返回空
        else if(!left && right) return right;	// 左空右不空,向上返回右
        else if(left && !right) return left;	// 左不空右空,向上返回左
        else return root;	// 左右都不空,root就是公共祖先,返回
    }
};

标签:node,right,TreeNode,val,int,二叉,搜索,二叉树,left
From: https://www.cnblogs.com/tazdingo/p/18021896

相关文章

  • Google搜索操作符:让你秒变搜索专家
    搜索引擎对互联网的重要性不言而喻,不过,随着ChatGPT及其类似AI工具的推出,对搜索引擎带来了前所未有的挑战。因为ChatGPT具有自然语言处理能力,能够更好地理解用户的搜索意图,提供更准确、更相关的搜索结果。同时,还可以根据用户的搜索历史和行为数据,为用户提供更加个性化的搜索体验,推......
  • 代码随想录算法训练营第二十二天|235. 二叉搜索树的最近公共祖先 ● 701.二叉搜索树
    二叉搜索树的最近公共祖先 题目链接:235.二叉搜索树的最近公共祖先-力扣(LeetCode)思路:只要利用二叉搜索树特性,只要当前节点的值位于要求的两个节点之间,就必定是我们要找的节点。最简单的一集。classSolution{public:TreeNode*lowestCommonAncestor(TreeNode*root,......
  • Spring Boot整合Postgres实现轻量级全文搜索
    有这样一个带有搜索功能的用户界面需求:搜索流程如下所示:这个需求涉及两个实体:“评分(Rating)、用户名(Username)”数据与User实体相关“创建日期(createdate)、观看次数(numberofviews)、标题(title)、正文(body)”与Story实体相关需要支持的功能对User实体中的评分(Rating)的频繁修......
  • [win_os] chrome浏览器 -- 添加自定义搜索引擎并将其设置为默认搜索引擎(转载裁切
    [win_os]  chrome浏览器 -- 添加自定义搜索引擎并将其设置为默认搜索引擎(转载裁切)    一、必要说明  1、添加搜索引擎【bing】:https://global.bing.com/search?q=%s  2、重点说明【红色部分一点都不能错】:https://global.bing.com/sea......
  • 代码随想录算法训练营第二十二天 | 450.删除二叉搜索树中的节点, 701.二叉搜索树中的
     450.删除二叉搜索树中的节点 已解答中等 相关标签相关企业 给定一个二叉搜索树的根节点 root 和一个值 key,删除二叉搜索树中的 key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。一般来说,删除节点......
  • 二叉树(2)
    目录538把二叉搜索树转换为累加树538把二叉搜索树转换为累加树和平常的遍历顺序不同这题根据题意是需要取比当前节点大的所有数值的和而在二叉搜索树中,节点的大小关系是左<中<右所以自然而然地我们就得到了如下的遍历顺序:右->中->左classSolution{public:intvalue......
  • 【持续更新中】【解题报告】你非得用贪心解深搜题吗?——搜索题迷惑解法大赏
    寒假THOI集训部分深搜题目(另类)题解今日推歌:《カブってこうぜぇfeat.可不》-タケノコ少年特别可爱的一个歌,,,Before集训时候做题做出的怪异解法和迷惑大赏,真实有用的成分低于迷惑成分除了深搜以后(可能)还会有广搜题本篇没有任何以贪心为正解的题,也(几乎)没有以正解(搜索)做出来......
  • 代码随想录算法训练营第二十天 | 236. 二叉树的最近公共祖先 , 501.二叉搜索树中的众
      530.二叉搜索树的最小绝对差 已解答简单 相关标签相关企业 给你一个二叉搜索树的根节点 root ,返回 树中任意两不同节点值之间的最小差值 。差值是一个正数,其数值等于两值之差的绝对值。 示例1:输入:root=[4,2,6,1,3]输出:1示......
  • 「力扣」104. 二叉树的最大深度
    「力扣」104.二叉树的最大深度题目描述给定一个二叉树root,返回其最大深度。二叉树的最大深度是指从根节点到最远叶子节点的最长路径上的节点数。示例1:输入:root=[3,9,20,null,null,15,7]输出:3示例2:输入:root=[1,null,2]输出:2提示:树中节点的数量在[0,10......
  • 代码随想录算法训练营第十九天 | 98.验证二叉搜索树, 700.二叉搜索树中的搜索,617.合并
     654.最大二叉树 已解答中等 相关标签相关企业 给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建:创建一个根节点,其值为 nums 中的最大值。递归地在最大值 左边 的 子数组前缀上 构建左子树......