题目描述(简单难度)

输出二叉树的深度。

解法一 DFS

依旧是考的二叉树的遍历。最简单的思路就是用递归进行 DFS 即可。

解法二 BFS

  1. Queue<TreeNode> queue = new LinkedList<TreeNode>();
  2. List<List<Integer>> ans = new LinkedList<List<Integer>>();
  3. if (root == null)
  4. return 0;
  5. int level = 0;
  6. while (!queue.isEmpty()) {
  7. for (int i = 0; i < levelNum; i++) {
  8. TreeNode curNode = queue.poll();
  9. if (curNode != null) {
  10. if (curNode.left != null) {
  11. queue.offer(curNode.left);
  12. if (curNode.right != null) {
  13. }
  14. }
  15. }
  16. level++;
  17. }
  18. return level;

依旧考的是二叉树的遍历方式,没有什么难点。

如果觉得有帮助的话,可以点击 这里 给一个 star 哦 ^^

如果想系统的学习数据结构和算法,强烈推荐一个我之前学过的课程,可以点击 查看详情