相同的树

leetcode100题:相同的树

给定两个二叉树,编写一个函数来检验它们是否相同。

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

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
求解:

 // Definition for a binary tree node.
  public class TreeNode {
      int val;
      TreeNode left;
      TreeNode right;
      TreeNode(int x) { val = x; }
  }
 
class Solution {
    public boolean isSameTree(TreeNode p, TreeNode q) {
        
        //判断是否有空树
        if(p==null && q==null){
            return true;
        }
        //左右节点分别递归判断
        if(p != null && q != null && q.val == p.val){
            return isSameTree(p.left,q.left) && isSameTree(p.right,q.right); 
        }else{
            return false;
        }
        
    }
}

总结

这是一道和树这种数据结构有关的一道leetcode上的题目,知识点个人认为是树的遍历这一块,借助这一道题目复习复习二叉树的前中后序遍历

递归形式的遍历实现比较简单,就不写出来了,主要想复习复习非递归方式遍历

前序遍历

private static void preOrder(TreeNode root){
	
	ArrayList<T> list = new ArrayList<>();
	Stack<TreeNode> stack = new Stack<>();
	if(root != null){
		stack.push(root);
		while(!stack.isEmpty()){
			TreeNode node = stack.pop();
			list.add(node.val);
			if(node.right != null){
				stack.push(node.right);
			}
			if(node.left != null){
				stack.push(node.left);
			}
		}
	}
	for(T i : list){
		System.out.println(i+"\t");
	}	
}

中序遍历

private static void order(TreeNode root){
	ArrayList<T> list = new ArrayList<>();
	Stack<TreeNode> stack = new Stack<>();
	while(root != null || !stack.isEmpty()){
		if(root != null){
			stack.push(root);
			root = root.left;
		}else{
			root = stack.pop();
			list.add(root.val);
			root = root.right;
		}
	}
	for(T i : list){
		System.out.println(i+"\t");
	}	
}

后序遍历

private static void order(TreeNode root){
	ArrayList<T> list = new ArrayList<>();
	Stack<TreeNode> stack = new Stack<>();
	Stack<TreeNode> resultStack = new Stack<>();
	while(root != null || !stack.isEmpty()){
		if(root != null){
			stack.push(root);
			resultStack.push(root);
			root = root.right;
		}else{
			root = stack.pop();
			root = root.left;
		}
	}
	while(!resultStack.isEmpty()){
		list.add(resultStack.pop().val);
	}
	for(T i : list){
		System.out.println(i+"\t");
	}	
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值