给定一个二叉树 root
,返回其最大深度。
二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。
思路:加一个变量,每次遍历层数时加1。
public static int maxDepth(TreeNode root) {
int deep=0;
//借助队列
Queue<TreeNode> queue=new LinkedList();
if(root!=null){
queue.add(root);
}
while (!queue.isEmpty()){
int size=queue.size(); //记录每层个数
deep++; //深度加1
for(int i=0;i<size;i++){
TreeNode node=queue.poll();
if(node.left!=null){
queue.add(node.left);
}
if(node.right!=null){
queue.add(node.right);
}
}
}
return deep;
}