The path sum of a path is the sum of the node’s values in the path.
Given the root
of a binary tree, return the maximum path sum of any path.
Example 1:
Input: root = [1,2,3]
Output: 6
Explanation: The optimal path is 2 -> 1 -> 3 with a path sum of 2 + 1 + 3 = 6.
Example 2:
Input: root = [-10,9,20,null,null,15,7]
Output: 42
Explanation: The optimal path is 15 -> 20 -> 7 with a path sum of 15 + 20 + 7 = 42.
Constraints:
-
The number of nodes in the tree is in the range [ 1 , 3 ∗ 1 0 4 ] [1, 3 * 10^4] [1,3∗104].
-
− 1000 < = N o d e . v a l < = 1000 -1000 <= Node.val <= 1000 −1000<=Node.val<=1000
判断两节点之间节点值和,最好从树叶到树根的遍历方式,所以用二叉树的后序遍历模式。
方法一:我写的。
方法二:别人写的,优雅了许多。
方法二中,当父节点值与左右子孙节点和值相加时,如果左右子孙节点和值是负数,那么干脆不采用它,也就是用0代替这节点值(如和为-9,它的父节点为n, n + ( − 9 ) < n + 0 n + (-9) < n + 0 n+(−9)<n+0
import com.lun.util.BinaryTree.TreeNode;
public class BinaryTreeMaximumPathSum {
private static int MIN_VALUE = -1001;//不用Integer.MIN_VALUE,原因是用它可能造成溢出情况
//方法一:我写的
public int maxPathSum(TreeNode root) {
int[] maxAlone = {MIN_VALUE};
int max = maxPathSum(root, maxAlone);
return Math.max(maxAlone[0], max);
}
private int maxPathSum(TreeNode node, int[] maxAlone) {
if(node == null) return MIN_VALUE;
int leftMax = maxPathSum(node.left, maxAlone);
int rightMax = maxPathSum(node.right, maxAlone);
int maxOne = Math.max(Math.max(leftMax, rightMax), //
leftMax + rightMax + node.val);
if(maxOne > maxAlone[0]) {
maxAlone[0] = maxOne;
}
return Math.max(Math.max(leftMax + node.val, rightMax + node.val),//
node.val);
}
//方法二:别人写的
public int maxPathSum2(TreeNode root) {
int[] max = {Integer.MIN_VALUE};
maxPathSum2(root, max);
return max[0];
}
private int maxPathSum2(TreeNode node, int[] max) {
if (node == null) return 0;
最后的内容
在开头跟大家分享的时候我就说,面试我是没有做好准备的,全靠平时的积累,确实有点临时抱佛脚了,以至于我自己还是挺懊恼的。(准备好了或许可以拿个40k,没做准备只有30k+,你们懂那种感觉吗)
如何准备面试?
1、前期铺垫(技术沉积)
程序员面试其实是对于技术的一次摸底考试,你的技术牛逼,那你就是大爷。大厂对于技术的要求主要体现在:基础,原理,深入研究源码,广度,实战五个方面,也只有将原理理论结合实战才能把技术点吃透。
下面是我会看的一些资料笔记,希望能帮助大家由浅入深,由点到面的学习Java,应对大厂面试官的灵魂追问
这部分内容过多,小编只贴出部分内容展示给大家了,见谅见谅!
- Java程序员必看《Java开发核心笔记(华山版)》
- Redis学习笔记
- Java并发编程学习笔记
四部分,详细拆分并发编程——并发编程+模式篇+应用篇+原理篇
- Java程序员必看书籍《深入理解 ava虚拟机第3版》(pdf版)
- 大厂面试必问——数据结构与算法汇集笔记
其他像Spring,SpringBoot,SpringCloud,SpringCloudAlibaba,Dubbo,Zookeeper,Kafka,RocketMQ,RabbitMQ,Netty,MySQL,Docker,K8s等等我都整理好,这里就不一一展示了。
2、狂刷面试题
技术主要是体现在平时的积累实用,面试前准备两个月的时间再好好复习一遍,紧接着就可以刷面试题了,下面这些面试题都是小编精心整理的,贴给大家看看。
①大厂高频45道笔试题(智商题)
②BAT大厂面试总结(部分内容截图)
③面试总结
3、结合实际,修改简历
程序员的简历一定要多下一些功夫,尤其是对一些字眼要再三斟酌,如“精通、熟悉、了解”这三者的区别一定要区分清楚,否则就是在给自己挖坑了。当然不会包装,我可以将我的简历给你参考参考,如果还不够,那下面这些简历模板任你挑选:
以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。
另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。
那下面这些简历模板任你挑选:
[外链图片转存中…(img-VDyopyKS-1719165023794)]
以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。
另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。