Smallest String Starting From Leaf
update Feb 3 2019, 23:41
Given the root of a binary tree, each node has a value from 0 to 25 representing the letters 'a' to 'z': a value of 0 represents 'a', a value of 1 represents 'b', and so on.
Find the lexicographically smallest string that starts at a leaf of this tree and ends at the root.
(As a reminder, any shorter prefix of a string is lexicographically smaller: for example, "ab" is lexicographically smaller than "aba". A leaf of a node is a node that has no children.)
Example 1:

Input: [0,1,2,3,4,3,4] Output: "dba"
Example 2:

Input: [25,1,3,1,3,0,2] Output: "adz"
Example 3:

Input: [2,2,1,null,1,0,null,0] Output: "abc"
Note:
The number of nodes in the given tree will be between 1 and 1000.
Each node in the tree will have a value between 0 and 25.
Basic Idea:
这道题是求所有从leaf出发到root结尾道path中,沿途经过node的val组成的string中字典顺序最小的string。
我们可以用分治的思路去解决,对于当前node,从leaf出发到该node结尾的path中最小的,一定是到它左孩子和到它右孩子结尾路径中最小的再append上node.val。这就是基本的思路,具体实现中还需要注意如果只有一边有子节点,则直接返回到该子节点的最小string再append上node本身。