剑指Offer之Java算法习题精讲二叉树专题篇下
更新时间:2022年03月18日 10:17:11 作者:明天一定.
跟着思路走,之后从简单题入手,反复去看,做过之后可能会忘记,之后再做一次,记不住就反复做,反复寻求思路和规律,慢慢积累就会发现质的变化
题目一
解法
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ class Solution { public int maxDepth(TreeNode root) { return method(root); } int method(TreeNode root){ if(root==null){ return 0; } int l = method(root.left); int r = method(root.right); return Math.max(l, r) + 1; } }
题目二
解法
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ class Solution { int ans = 0; public int diameterOfBinaryTree(TreeNode root) { method(root); return ans; } public int method(TreeNode root){ if(root==null){ return 0; } int l = method(root.left); int r = method(root.right); ans = Math.max(ans,l+r); return Math.max(l,r)+1; } }
题目三
解法
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ class Solution { public int minDepth(TreeNode root) { if(root==null) return 0; if(root.left==null&&root.right==null) return 1; int min = Integer.MAX_VALUE; if(root.left!=null){ min = Math.min(min,minDepth(root.left)); } if(root.right!=null){ min = Math.min(min,minDepth(root.right)); } return min+1; } }
题目四
解法
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ class Solution { List<Integer> list = new ArrayList<Integer>(); public List<Integer> preorderTraversal(TreeNode root) { method(root); return list; } public void method(TreeNode root){ if(root==null){ return; } // 前序 list.add(root.val); method(root.left); // 中序 method(root.right); // 后序 } }
到此这篇关于剑指Offer之Java算法习题精讲二叉树专题篇下的文章就介绍到这了,更多相关Java 二叉树内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
java中自定义Spring Security权限控制管理示例(实战篇)
本篇文章主要介绍了java中自定义Spring Security权限控制管理示例(实战篇) ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。2017-02-02Spring3 整合MyBatis3 配置多数据源动态选择SqlSessionFactory详细教程
这篇文章主要介绍了Spring3 整合MyBatis3 配置多数据源动态选择SqlSessionFactory详细教程,需要的朋友可以参考下2017-04-04使用spring oauth2框架获取当前登录用户信息的实现代码
这篇文章主要介绍了使用spring oauth2框架获取当前登录用户信息的实现代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-07-07SpringBoot使用Validator进行参数校验实战教程(自定义校验,分组校验)
这篇文章主要介绍了SpringBoot使用Validator进行参数校验(自定义校验,分组校验)的实战教程,本文通过示例代码给大家介绍的非常详细,需要的朋友参考下吧2023-07-07SpringBoot 自动扫描第三方包及spring.factories失效的问题解决
这篇文章主要介绍了SpringBoot 自动扫描第三方包及spring.factories失效的问题,本文给大家分享最新解决方法,需要的朋友可以参考下2023-05-05
最新评论