剑指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 {int ans; int pre; public int getMinimumDifference(TreeNode root) {ans = Integer.MAX_VALUE; pre = -1; method(root); return ans; }public void method(TreeNode root){if(root==null) return; method(root.left); if(pre==-1){pre = root.val; }else{ans = Math.min(ans,root.val-pre); pre = root.val; }method(root.right); }}
题目二
文章图片
解法
/** * 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 findTilt(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.abs(l-r); return l+r+root.val; }}
题目三
文章图片
【剑指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 boolean isSubtree(TreeNode root, TreeNode subRoot) {return dfs(root,subRoot); }public boolean dfs(TreeNode root, TreeNode subRoot){if(root==null) return false; return cheack(root,subRoot)||dfs(root.left,subRoot)||dfs(root.right,subRoot); }public boolean cheack(TreeNode root, TreeNode subRoot){if(root==null&&subRoot==null) return true; if(root==null||subRoot==null||root.val!=subRoot.val) return false; return cheack(root.left,subRoot.left)&&cheack(root.right,subRoot.right); }}
题目四
文章图片
解法
/** * 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 boolean isSameTree(TreeNode p, TreeNode q) {if(p==null&&q==null) return true; if(p==null||q==null||q.val!=p.val) return false; return isSameTree(p.left,q.left)&&isSameTree(p.right,q.right); }}
到此这篇关于剑指Offer之Java算法习题精讲二叉树专项解析的文章就介绍到这了,更多相关Java 二叉树内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 剑指Offer之Java算法习题精讲二叉树与链表
- 剑指Offer之Java算法习题精讲排列与N叉树
- 剑指Offer之Java算法习题精讲二叉树与斐波那契函数
- 剑指Offer之Java算法习题精讲链表专题篇
- 剑指Offer之Java算法习题精讲二叉树专题篇下
- 剑指Offer之Java算法习题精讲二叉树与N叉树
- 不归路之Python|什么是计算机网络(为什么需要网络通信?如何进行网络编程?)
- Python自动化办公之邮件发送全过程详解
- Unity实战之FlyPin(见缝插针)小游戏的实现
- 手写|手写 Vue2 系列 之 patch —— diff