当前位置: 首页 > news >正文

二叉树习题精讲-相同的树

相同的树

100. 相同的树 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/same-tree/description/

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/
bool isSameTree(struct TreeNode* p, struct TreeNode* q) {if (p == NULL && q == NULL)return true;if (p == NULL || q == NULL)return false;if (p->val != q->val)return false;return isSameTree(p->left,q->left) &&  isSameTree(p->right,q->right);
}

解释:

  1. bool isSameTree(struct TreeNode* p, struct TreeNode* q)

    • 这是函数的声明行,定义了一个名为 isSameTree 的函数。它接收两个参数,分别是指向 TreeNode 结构体的指针 p 和 q,表示要比较的两棵树的根节点。函数返回一个布尔值 bool,如果两棵树相同则返回 true,否则返回 false
  2. if (p == NULL && q == NULL)

    • 这行代码检查两个节点 p 和 q 是否都为空。如果都为空,说明两棵树在当前节点上是相同的(都是空树),因此返回 true
  3. if (p == NULL || q == NULL)

    • 这行代码检查两个节点 p 和 q 中是否有一个为空而另一个不为空。如果存在这样的情况,说明两棵树至少在当前节点上就不同,因此返回 false
  4. if (p->val != q->val)

    • 这行代码检查两个节点 p 和 q 的值是否不同。如果值不同,说明两棵树在当前节点上不相同,因此返回 false
  5. return isSameTree(p->left,q->left) && isSameTree(p->right,q->right);

    • 如果当前节点 p 和 q 都不为空且值相同,这行代码递归地调用 isSameTree 函数,分别比较 p 的左子节点和 q 的左子节点,以及 p 的右子节点和 q 的右子节点。只有当左子树和右子树都相同,整个树才被认为是相同的,因此返回两个递归调用的结果的逻辑与(&&)。

总结来说,isSameTree 函数通过递归的方式比较两棵树的每个节点。首先检查当前节点是否为空,如果不为空再检查节点的值是否相同。如果所有对应的节点都相同,那么函数返回 true,表示两棵树相同;如果任何一对对应节点不同,函数返回 false,表示两棵树不同。

http://www.lryc.cn/news/356673.html

相关文章:

  • 「架构」模型驱动架构设计方法及其运用
  • 基于 React + Nest 全栈开发的后台系统
  • jQuery值操作例子 (代码)
  • Next-Admin,一款基于Nextjs开发的开箱即用的中后台管理系统(全剧终)
  • HTML5 文件处理及应用
  • 逻辑分析仪的调试使用
  • AI学习指南数学工具篇-Python中的凸优化库
  • 数据库mysql
  • AWS联网和内容分发之Transit Gateway
  • 牛客NC236 最大差值【simple 动态规划 Java/Go/PHP】
  • ORACLE 6节点组成的ACFS文件系统异常的分析思路
  • vscode当前分支有未提交的修改,但是暂时不想提交,想要切换到另一个分支该怎么办
  • 前端API: IntersectionObserver的那一二三件事
  • C++迈向精通:vector复现与sort复现
  • 【头歌】计算机网络DHCP服务器配置第二关access口配置答案
  • Python机器学习 Tensorflow + keras 实现CNN
  • 基于事件的架构工作机制和相关产品
  • OSINT 与心理学:通过开源情报进行剖析和行为分析
  • yarn 设置淘宝镜像配置
  • debian 常用命令
  • 流水账(CPU设计实战)——lab3
  • k8s集群配置普通用户权限
  • clickhouse——clickhouse单节点部署及基础命令介绍
  • MATLAB基础应用精讲-【数模应用】价格敏感度PSM分析(附python代码实现)
  • 数据驱动的UI艺术:智能设计的视觉盛宴
  • 栈的特性及代码实现(C语言)
  • 防火墙如何端口映射?
  • 咖啡看书休闲时光404错误页面源码
  • 中央事件bus
  • 中国上市企业行业异质性数据分析