🎁个人主页:我们的五年
🔍系列专栏:初阶初阶结构刷题
🎉欢迎大家点赞👍评论📝收藏⭐文章
1.问题描述:
2.问题分析:
二叉树是区分结构的,即左右子树是不一样的。本题还是采用分治的思想,要让两棵子树相等,只要让根相等,左子树相等,右子树相等就可以了。
力扣官方给的函数模型:
bool isSameTree(struct TreeNode* p, struct TreeNode* q) {
}
能往下走的条件是根一样。能往下走的条件我们不管,要管的是不能往下走的时候,之间返回false。
if(p->val!=q->val)
return false;
最小子问题是:根都一样,q和p要么都为空,要么有一个为空。
走到有一颗子树的根为NULL,就进行判断。
/*** 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);
}
if(p==NULL&&q==NULL)
{
return true;
}
if(p==NULL||q==NULL)
{
return false;
}
这两个是最小子问题的时候进行返回,即有一个都为NULL了,另外一个要是还不是空,两边就不相等了。
if(p->val!=q->val)
return false;
根都不相等了,直接返回。所以返回的条件有三个,根相等,子树相等,子树不相等。但是只有都走到NULL才是返回true。
左边相等,右边相等就返回true。
return isSameTree(p->left,q->left)&&isSameTree(p->right,q->right);