判断两棵二叉树是否相同之java实现

package com.cb.java.algorithms.jianzhioffer.tree;

/**
 * 判断两个二叉树是否相同
 * 
 * @author 36184
 *
 */
public class SameTree {
	public boolean isSameTree(TreeNode first, TreeNode second) {
		// 如果两颗树都为空则相同
		if (first == null && second == null) {
			return true;
		}
		// 如果其中一棵树为空,则不同
		else if (first == null || second == null) {
			return false;
		}
		// 如果两颗谁都不为空,则判断左右子树是否相同
		if (first != null && second != null) {
			if (first.data != second.data)
				return false;
			else
				return isSameTree(first.left, second.left) && isSameTree(first.right, second.right);
		}
		return false;
	}
}

class TreeNode {
	int data; // 数据域
	TreeNode left;// 左子节点
	TreeNode right; // 右子节点

	public TreeNode(int data) {
		this.data = data;
	}
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值