[B] [C] [D]
Given the root node of a complete binary tree, find the number of nodes in the tree.
A complete binary tree is defined as follows: In a complete binary tree, the number of nodes in each layer reaches the maximum except that the lowest node may not be filled, and the nodes in the lowest layer are concentrated in the leftmost positions of the layer. If the lowest layer is layer H, this layer contains 1 to 2h nodes.
Example 1:
Input: root = [1,2,3,4,5,6] output: 6Copy the code
Example 2:
Input: root = [] Output: 0Copy the code
Example 3:
Input: root = [1] Output: 1Copy the code
Tip:
- The number of nodes in the tree ranges from
[0, 5 * 104]
0 <= Node.val <= 5 * 104
- The problem data guarantees that the input tree is a complete binary tree
Advanced: Traversing the tree to count nodes is a simple O(n) time solution. Can you design a faster algorithm?
Counting nodes is a simple solution, requiring us to design a faster algorithm
Here’s the faster algorithm
- Because the input binary tree is a complete binary tree, the number of nodes in every previous layer is full except for the last one
- Given this property, assume that the total number of layers is
h
, the number of nodes before the last layer is2
的h-1
The power cut1
- Then the number of nodes in the last layer can be added up to obtain the result value
- The quantity of the last layer needs to be obtained by dichotomy plus to determine whether the node exists
And the time of this better solution is order log base 2n.
My personal opinion here is that although the time complexity is optimized, the optimization degree is not high, and the whole problem solving process is a lot of tedious, so I still adopted the recursive traversal of the number of binary tree records to solve the problem.
If you are interested in the optimal solution, you can go to the problem solving section to see the official problem solving study.
The solution code for traversing the binary tree is as follows:
Var countNodes = function(root) {// create result value, initialize to 0 let res = 0; Function getNum(root){if(root === null) return; res++; getNum(root.left); getNum(root.right); } getNum(root); // return res; };Copy the code
At this point we have completed the number of nodes in leetcode-222- complete binary tree
If you have any questions or suggestions, please leave a comment!