import java.util.*; /* * public class TreeNode { * int val = 0; * TreeNode left = null; * TreeNode right = null; * public TreeNode(int val) { * this.val = val; * } * } */ public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param root TreeNode类 * @return int整型 */ public static int max_depth = 0; public int maxDepth (TreeNode root) { // write code here search(root, 0); return max_depth; } public void search(TreeNode root, int cur) { if (root == null) { max_depth = Math.max(cur, max_depth); return; } search(root.left, cur + 1); search(root.right, cur + 1); } }
本题考察的知识点为二叉树的遍历,所用编程语言为java.二叉树的遍历方法有四种
1.前序遍历,先遍历根节点,再遍历左节点,最后遍历右节点
2.中序遍历,先遍历左节点,再遍历根节点,最后遍历右节点
3.后序遍历,先遍历左节点,在便利右节点,最后遍历根节点
4.层序遍历,每层结点从左到右依次访问,常用队列实现遍历操作
关于这题,我们可以考虑使用前序遍历、中序遍历、后序遍历的任何一种进行实现,比较每条从根节点到叶子结点的路径长度,得到最长路径,关于这题我是使用的前序遍历。