У меня проблемы с созданием метода печати (void) для печати всех
поля в дереве.
Я нашел и адаптировал следующее (я думаю, из rosettacode.org/wiki/AVL_tree). С тех пор это мой любимый.
void showNodeAtLvl(int lvl) {
std::cout << std::setw(lvl) << m_key << std::endl; }
template <class T>
void BBT::AVLtree<T>::showTallTree(AVLnode<T>* n, int lvl)
{
if (nullptr != n)
{
showTallTree(n->m_left, lvl+1);
n->showNodeAtLvl(7*lvl);
showTallTree(n->m_right, lvl+1);
}
}
Мой фрагмент использует указатели на левый и правый узлы, и вам нужно будет заменить указатели на вашу схему индексации массива (когда вы это выясните)
Пример теста и вывода:
Inserting values 11 to 41
tree.showTallTree:
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
Примечание. Середина примера и корень дерева имеют значение 26 слева. Листья деревьев справа.