剑指Offer之Java算法习题精讲二叉树专题篇下
题目一
文章图片
解法
/** * 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) {returnmethod(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 {Listlist = new ArrayList (); public List 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算法习题精讲二叉树专题篇下】到此这篇关于剑指Offer之Java算法习题精讲二叉树专题篇下的文章就介绍到这了,更多相关Java 二叉树内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 剑指Offer之Java算法习题精讲二叉树与N叉树
- 不归路之Python|什么是计算机网络(为什么需要网络通信?如何进行网络编程?)
- Python自动化办公之邮件发送全过程详解
- Unity实战之FlyPin(见缝插针)小游戏的实现
- 手写|手写 Vue2 系列 之 patch —— diff
- leetcode|算法入门之字符串(Python)【初级算法——字符串】【蓝桥杯练习】【力扣练习】
- redis|秒杀项目前期之登录功能
- java|秒杀项目(二)之验证功能&&全局共享&&参数解析器
- C++|蓝桥杯之奇妙的数字
- 第二次月计划|2年学完6个清华CS类硕士学位之第五次周计划