首页 > 其他分享 >相同二叉树和镜面二叉树问题

相同二叉树和镜面二叉树问题

时间:2023-12-19 23:47:37浏览次数:34  
标签:right 相同 镜面 二叉树 && null root left

相同二叉树和镜面二叉树问题

作者:Grey

原文地址:

博客园:相同二叉树和镜面二叉树问题

CSDN:相同二叉树和镜面二叉树问题

判断两棵树是否是相同的树

题目描述见:LeetCode 100. Same Tree

即:如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。

比如:

image

两个树结构完全一致,对应位置上的值也一致,即为相同的树,以下两种情况都不是相同的树:

image

image

思路也很简单,首先,两棵空树是相同的树,只有一棵树是空树,则一定不是相同的树,即

if (p == null || q == null) {
    // 两个同时为空才表示 same tree
    return q == null && p == null;
}

除此以外,两棵树的头节点的值相等,才有可能是相同的树

p.val == q.val

而且,还需要满足,p 的左子树和 q 的左子树是相同的树且 p 的右子树和 q 的右子树是相同的树,这几个条件同时满足,才是相同的树,以上条件整合一下,即:

return p.val == q.val && isSameTree(p.left, q.left) && isSameTree(p.right, q.right);

完整代码为

public boolean isSameTree(TreeNode p, TreeNode q) {
	if (p == null || q == null) {
		// 两个树同时为空才表示 same tree
		return q == null && p == null;
	}
	return p.val == q.val && isSameTree(p.left, q.left) && isSameTree(p.right, q.right);
}

镜面二叉树问题

题目描述见:LeetCode 101. Symmetric Tree

即:判断一个树是否轴对称。

比如这个二叉树,就是轴对称的:

image

以下这个二叉树,就不是轴对称的,

image

本题的思路如下:

首先,空树一定是镜面二叉树

if (null == root) {
    return true;
}

此外,左右子树同时为空的时候,是镜面二叉树

if (root.left == null || root.right == null) {
	return root.left == null && root.right == null;
}

接下来定义递归函数

boolean isSymmetric(TreeNode left, TreeNode right)

递归含义是:判断 left 和 right 这两棵树是否是镜面对称。

base case 是

if (left == null || right == null) {
// 两棵树同时为空才镜面对称
	return left == null && right == null;
}

普遍情况,首先要满足,left 树头节点的值和 right 树头节点的值一样,然后是 left 的左子树和 right 的右子树镜面对称,且 left 树的右子树和 right 树的左子树镜面对称,三个条件同时满足,left 和 right 才镜面对称

public boolean isSymmetric(TreeNode left, TreeNode right) {
	if (left == null || right == null) {
		return left == null && right == null;
	}
	// left.val == right.val
	return left.val == right.val && isSymmetric(left.left, right.right) && isSymmetric(left.right, right.left);
}

主函数直接调用这个递归方法:

public boolean isSymmetric(TreeNode root) {
	if (null == root) {
		return true;
	}
	if (root.left == null || root.right == null) {
		return root.left == null && root.right == null;
	}
	return root.left.val == root.right.val && isSymmetric(root.left, root.right);
}

更多

算法和数据结构学习笔记

算法和数据结构学习代码

参考资料

算法和数据结构体系班-左程云

标签:right,相同,镜面,二叉树,&&,null,root,left
From: https://www.cnblogs.com/greyzeng/p/16971977.html

相关文章

  • Python算法——二叉树遍历
    Python中的二叉树遍历算法详解二叉树是一种常见的树状数据结构,每个节点最多有两个子节点,分别称为左子节点和右子节点。遍历二叉树是访问树的所有节点并按照特定顺序输出它们的过程。在本文中,我们将讨论二叉树的三种主要遍历算法:前序遍历、中序遍历和后序遍历,并提供相应的Python代码......
  • java实现二叉树前序搜索输出深度完整代码
    importjava.util.Scanner;//1:无需package//2:类名必须Main,不可修改classTreeNode{publicintval;publicTreeNodeleft;publicTreeNoderight;publicTreeNode(intval){this.val=val;this.left=null;this.right=null;}}p......
  • 删除序列相同元素并保持顺序
    问题怎样在一个序列上面保持元素顺序的同时消除重复的值?解决方案如果序列上的值都是hashable类型,那么可以很简单的利用集合或者生成器来解决这个问题。比如:defdedupe(items):seen=set()foriteminitems:ifitemnotinseen:yielditemseen.add(item) 下面是使......
  • C语言 层次遍历二叉树
    代码如下#include<stdio.h>#include<stdlib.h>#defineMax_Size50typedefstructbitree{chardata;intlevel;structbitree*lchild;structbitree*rchild;}BiTreeNode,*BiTree;typedefstructqueue{BiTreeData[Max_Size];......
  • C++U5-10-二叉树3
    学习目标 二叉树重建的概念 二叉树重建流程 例题和解题思路 2 3 4 5 [【二叉树】求先序排列]  代码【算法分析】后序遍历的最后一个是根节点,由这个根节点可以在中序遍历中确定左子树和右子树的大小和元素,然后递归的去处理左子树和右子树,由于是......
  • 3D 高斯喷溅 为什么图形永远不会相同
    高斯喷溅 (Gaussian Splatting) 技术是一种翻天覆地的渲染手段,能够以 144 帧每秒的速度渲染出高质量的场景,这和传统的图形处理流程截然不同......
  • 【教3妹学编程-算法题】反转二叉树的奇数层
    3妹:“你不是真正的快乐,你的笑只是你穿的保护色”2哥 :3妹还在唱五月天的歌啊,你不知道五月天假唱,现在全网都在骂呢。3妹:知道啊,可是关我什么事,这个歌的确好听啊。2哥 :嗯嗯,不错,还以为你是脑残粉,无论黑白都只管追星呢。3妹:我是只管追歌的,歌好听就行啦。2哥 :追哥?追哪个哥,难......
  • 第六章 二叉树part01
    第六章二叉树**part01**  递归遍历 144.二叉树的前序遍历 Code:/***Definitionforabinarytreenode.*structTreeNode{*  intval;*  TreeNode*left;*  TreeNode*right;*  TreeNode():val(0),left(nullptr),right(nullpt......
  • 二叉树
    二叉排序树classNode{ constructor(value){ this.value=value this.left=null this.right=null }}classTree{ constructor(){ this.root=null this.travelResult=[] } insertByFather(father,node){ if(father.value>node.value){ ......
  • 655. 输出二叉树(中)
    目录题目题解题目给你一棵二叉树的根节点root,请你构造一个下标从0开始、大小为mxn的字符串矩阵res,用以表示树的格式化布局。构造此格式化布局矩阵需要遵循以下规则:树的高度为height,矩阵的行数m应该等于height+1。矩阵的列数n应该等于2的(height+1)次......