Given a binary tree, find its minimum depth.
The minimum depth is the number of nodes along the shortest path from the root node down to the nearest leaf node.
Note
A leaf is a node with no children.
Example
Given binary tree [3,9,20,null,null,15,7],
| 1 | 3 | 
return its minimum depth = 2.
O(n) runtime, O(log n) space – Depth-first traversal
| 1 | public class TreeNode { | 
| 1 | public int minDepth(TreeNode root) { | 
O(n) runtime, O(n) space – Breadth-first traversal
| 1 | public class TreeNode { | 
| 1 | public int minDepth(TreeNode root) { |