Como construir uma árvore binária usando uma sequência transversal de ordem de nível
Como construir uma árvore binária usando uma sequência transversal de ordem de nível, por exemplo, a partir da sequência {1,2,3, #, #, 4, #, #, 5}, podemos construir uma árvore binária como esta:
1
/ \
2 3
/
4
\
5
onde '#' significa um terminador de caminho em que nenhum nó existe abaixo.
Por fim, implementei o algoritmo de Pham Trung por c ++
struct TreeNode
{
TreeNode *left;
TreeNode *right;
int val;
TreeNode(int x): left(NULL), right(NULL), val(x) {}
};
TreeNode *build_tree(char nodes[], int n)
{
TreeNode *root = new TreeNode(nodes[0] - '0');
queue<TreeNode*> q;
bool is_left = true;
TreeNode *cur = NULL;
q.push(root);
for (int i = 1; i < n; i++) {
TreeNode *node = NULL;
if (nodes[i] != '#') {
node = new TreeNode(nodes[i] - '0');
q.push(node);
}
if (is_left) {
cur = q.front();
q.pop();
cur->left = node;
is_left = false;
} else {
cur->right = node;
is_left = true;
}
}
return root;
}