力扣993-二叉树的堂兄弟节点

二叉树的堂兄弟节点

题目链接

解题思路

  1. 题目要求我们找到x和y处于同样的深度,但是父节点不同,返回true,否则返回false
  2. dfs()函数参数解读
    1. TreeNode*root:是此时正要处理的节点
    2. int x:表示我们要寻找的x和y
    3. int fa:表示正在处理的节点的父节点的值
    4. int depth:表示此时正在处理的节点的深度
  3. dfs()函数返回一个数组,第一个值是目标节点的父节点的值,第二个值是目标节点的深度
  4. 如果说当前处理的节点为空,那么直接返回{0,0}
  5. 如果找到目标节点,则返回父节点和深度{fa,depth}
  6. 之后就是递归左子树和右子树,深度+1,父节点为当前节点的值
  7. 其实,左右子树递归时,只有一个子树包含目标值(因为所有的值只会出现一次),另一个子树返回{0,0}
  8. 所以最后返回{l[0]+r[0],l[1]+r[1]};
c++ 复制代码
/**
 * 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:
    vector<int> dfs(TreeNode* root,int x,int fa,int depth){
        if(!root) return {0,0};
        if(root->val == x) return {fa,depth};
        auto l = dfs(root->left,x,root->val,depth+1);
        auto r = dfs(root->right,x,root->val,depth+1);
        return {l[0]+r[0],l[1]+r[1]};
    }
    bool isCousins(TreeNode* root, int x, int y) {
        auto a = dfs(root,x,-1,0);
        auto b = dfs(root,y,-1,0);
        if(a[0] != b[0] && a[1] ==b[1]){
            return true;
        }else{
            return false;
        }
    }
};
相关推荐
呃呃本7 小时前
算法题(矩阵)
线性代数·算法·矩阵
呃呃本7 小时前
算法题(普通数组、矩阵)
线性代数·算法·矩阵
计算机安禾7 小时前
【计算机网络】第11篇:链路状态路由协议——Dijkstra算法与OSPF的分区架构
计算机网络·算法·架构
珂朵莉MM7 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第二赛季优化题--遗传算法
人工智能·算法
gihigo19987 小时前
严格耦合波分析计算光栅衍射效率算法
算法
可编程芯片开发7 小时前
基于双Qlearning强化学习的温差发电系统电压动态补偿算法matlab仿真
算法·matlab·双qlearning强化学习·电压动态补偿·温差发电系统
Java成神之路-7 小时前
【LeetCode 刷题笔记】69.x 的平方根 | 二分查找经典刷题题解
算法·leetcode
灵智实验室7 小时前
PX4状态估计技术EKF2详解(一):EKF2 开篇——从分离到统一
算法·无人机·px 4
小智老师PMP7 小时前
六月PMP晚启动急救|现在开始,每天2-3小时,稳冲一次上岸(附可直接照搬计划)
算法·软件工程·求职招聘·产品经理·敏捷流程
tankeven7 小时前
动态规划专题(11):区间动态规划之三角剖分问题
c++·算法·动态规划