这是悦乐书的第334次更新,第358篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第204题(顺位题号是872)。考虑二叉树的所有叶子,从左到右的顺序,这些叶子的值形成叶子值序列。



例如,在上面给定的树中,叶子值序列是(6,7,4,9,8)。

如果两个二叉树的叶子值序列相同,则认为两个二叉树是叶子相似的。当且仅当具有头节点root1和root2的两个给定树是叶类似的时,才返回true。

注意

  • 两个给定的树将具有1到100个节点。

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

题目的意思是给定两个二叉树,如果它们的叶子值都相等,就返回true。

也就是说,我们需要拿到二叉树的所有叶子节点的值,然后依次比较,如果相等就返回true。

从树的结构上来看,使用广度遍历的方式更好,整体思路就是使用广度优先算法,得到叶子节点值数组,再比较数组值判断是否相等。

此解法是借助栈,通过迭代的方式来实现广度优先算法。

  1. /**
  2. * Definition for a binary tree node.
  3. * public class TreeNode {
  4. * int val;
  5. * TreeNode left;
  6. * TreeNode right;
  7. * TreeNode(int x) { val = x; }
  8. * }
  9. */
  10. class Solution {
  11. public boolean leafSimilar(TreeNode root1, TreeNode root2) {
  12. List<Integer> list = getLeafValue(root1);
  13. List<Integer> list2 = getLeafValue(root2);
  14. if (list.size() != list2.size()) {
  15. return false;
  16. }
  17. for (int i=0; i<list.size(); i++) {
  18. if (list.get(i) != list2.get(i)) {
  19. return false;
  20. }
  21. }
  22. return true;
  23. }
  24. public List getLeafValue(TreeNode root){
  25. List<Integer> list = new ArrayList<Integer>();
  26. Stack<TreeNode> stack = new Stack<TreeNode>();
  27. stack.push(root);
  28. while (!stack.isEmpty()) {
  29. int size = stack.size();
  30. for (int i=0; i<size; i++) {
  31. TreeNode node = stack.pop();
  32. if (node.left != null) {
  33. stack.push(node.left);
  34. }
  35. if (node.right != null) {
  36. stack.push(node.right);
  37. }
  38. if (node.left == null && node.right == null) {
  39. list.add(node.val);
  40. }
  41. }
  42. }
  43. return list;
  44. }
  45. }

03 第二种解法

针对广度优先算法,我们也可以使用递归的方式来实现。

递归方法中使用了两个参数,一是二叉树本身,二是存储叶子节点值的数组。

  1. /**
  2. * Definition for a binary tree node.
  3. * public class TreeNode {
  4. * int val;
  5. * TreeNode left;
  6. * TreeNode right;
  7. * TreeNode(int x) { val = x; }
  8. * }
  9. */
  10. class Solution {
  11. public boolean leafSimilar(TreeNode root1, TreeNode root2) {
  12. List<Integer> list = new ArrayList<Integer>();
  13. List<Integer> list2 = new ArrayList<Integer>();
  14. getLeafValue(root1, list);
  15. getLeafValue(root2, list2);
  16. if (list.size() != list2.size()) {
  17. return false;
  18. }
  19. for (int i=0; i<list.size(); i++) {
  20. if (list.get(i) != list2.get(i)) {
  21. return false;
  22. }
  23. }
  24. return true;
  25. }
  26. public void getLeafValue(TreeNode root, List<Integer> list){
  27. if (root != null) {
  28. if (root.left == null && root.right == null) {
  29. list.add(root.val);
  30. }
  31. getLeafValue(root.left, list);
  32. getLeafValue(root.right, list);
  33. }
  34. }
  35. }

04 第三种解法

在第二种解法的基础上,我们可以将数组换成字符串,思路和效果都是一样的。

  1. /**
  2. * Definition for a binary tree node.
  3. * public class TreeNode {
  4. * int val;
  5. * TreeNode left;
  6. * TreeNode right;
  7. * TreeNode(int x) { val = x; }
  8. * }
  9. */
  10. class Solution {
  11. public boolean leafSimilar(TreeNode root1, TreeNode root2) {
  12. StringBuilder sb = new StringBuilder();
  13. StringBuilder sb2 = new StringBuilder();
  14. getLeafValue(root1, sb);
  15. getLeafValue(root2, sb2);
  16. return sb.toString().equals(sb2.toString());
  17. }
  18. public void getLeafValue(TreeNode root, StringBuilder sb){
  19. if (root != null) {
  20. if (root.left == null && root.right == null) {
  21. sb.append(root.val);
  22. }
  23. getLeafValue(root.left, sb);
  24. getLeafValue(root.right, sb);
  25. }
  26. }
  27. }

05 小结

算法专题目前已连续日更超过六个月,算法题文章204+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode.872-叶子值相等的树(Leaf-Similar Trees)的更多相关文章

  1. LeetCode 872. 叶子相似的树(Leaf-Similar Trees)

    872. 叶子相似的树 872. Leaf-Similar Trees 题目描述 请考虑一颗二叉树上所有的叶子,这些叶子的值按从左到右的顺序排列形成一个叶值序列. LeetCode872. Leaf- ...

  2. [leetcode] 872. 叶子相似的树(周赛)

    872. 叶子相似的树 前序遍历,记录叶子节点即可 class Solution { private static String ans = ""; public boolean ...

  3. Leetcode 872. 叶子相似的树

    题目链接 https://leetcode-cn.com/problems/leaf-similar-trees/description/ 题目描述 请考虑一颗二叉树上所有的叶子,这些叶子的值按从左到 ...

  4. 【bzoj3685】普通van Emde Boas树 权值zkw线段树

    原文地址:http://www.cnblogs.com/GXZlegend/p/6809743.html 题目描述 设计数据结构支持:1 x  若x不存在,插入x2 x  若x存在,删除x3    输 ...

  5. 表达式树(Expression Trees)

    [翻译]表达式树(Expression Trees) 原文地址:https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/con ...

  6. Java实现 LeetCode 677 键值映射(字典树)

    677. 键值映射 实现一个 MapSum 类里的两个方法,insert 和 sum. 对于方法 insert,你将得到一对(字符串,整数)的键值对.字符串表示键,整数表示值.如果键已经存在,那么原来 ...

  7. 【LeetCode】988. Smallest String Starting From Leaf 解题报告(C++ & Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 DFS BFS 日期 题目地址:https://le ...

  8. 【leetcode】988. Smallest String Starting From Leaf

    题目如下: Given the root of a binary tree, each node has a value from 0 to 25representing the letters 'a ...

  9. 【LeetCode】1022. Sum of Root To Leaf Binary Numbers 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 DFS 日期 题目地址:https://leetco ...

随机推荐

  1. squid之------ACL控制

    一.ACL概念   Squid提供了强大的代理控制机制,通过合理设置ACL(Access Control List,访问控制列表)并进行限制,可以针对源地址.目标地址.访问的URL路径.访问的时间等各 ...

  2. Maven工程构建

    Maven 相关术语: 本地资源库:用来存储项目的依赖库,默认的文件夹是 “.m2” 目录 中央存储库: 用来下载所有项目的依赖库的默认位置 Maven pom.xml: 项目对象模型(Project ...

  3. vuex 管理状态

    来分析下vuex的管理状态吧,如果你用过react中的redux的管理树,那我觉得vuex对你来说很容易掌握 如果你还是不太熟悉vuex是什么,那先看下官网https://vuex.vuejs.org ...

  4. 微信公众号发送告警Python脚本

    调用该脚本,可以向微信公众号发生告警. #!/bin/env python #coding:utf-8 #Author: Hogan #Descript : 微信公众号发送告警脚本 import ur ...

  5. react项目导出数据怎么做?

    做项目遇到导出数据,搜索了一个插件,简直太好用,几行代码就可以搞定. 插件是react-csv, 了解详细介绍大家可以去https://www.npmjs.com/package/react-csv

  6. 配置MongoDB的Windows服务

    [1] 创建directorys和files Create a configuration file and a directory path for MongoDB log output (logp ...

  7. CF191C Fools and Roads - 树剖解法

    Codeforces Round #121 (Div. 1) C. Fools and Roads time limit per test :2 seconds memory limit per te ...

  8. object-fit 用于图片适应

    参考文章: object-fit

  9. 5.Python注释(多行注释和单行注释)用法详解

    Python单行注释 Python 中使用井号(‘#’)作为单行注释的符号,语法格式为: # 注释内容 也就是说,从符号‘#’处开始,直到换行处结束,此部分内容都作为注释的内容,当程序执行时,这部分内 ...

  10. Starting MySQL... ERROR! The server quit without updating PID file (/usr/local/mysql/data/VM_0_6_centos.pid)

    刚接触MySql数据库,参考一些文章后搭建起来了也创建了数据库,程序跑到很好,一觉醒来突然连接不上了 MySql数据库了. 研究了好一会才找到原因. 现象: 登录数据库失败 [root@VM_0_6_ ...