Как обеспечить правильное разрушение нерегулярного дерева?C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Как обеспечить правильное разрушение нерегулярного дерева?

Сообщение Anonymous »

следует минимально воспроизводимому примеру: < /p>
#include
#include

template
struct TreeNode {
T data;
std::vector children;
TreeNode(const T& d = T(), const std::vector& ch = {})
: data(d)
, children(ch)
{}
};

template
void destruct(TreeNode*& root) {
if (!root) return;
destructRec(root);
root = nullptr;
}

template
void destructRec(TreeNode*& root) {
for (TreeNode* child : root->children) {
destructRec(child);
}
delete root;
std::cout children.push_back(child);
return root;
}

int main() {
TreeNode* root = createTree();
destruct(root); // by throwing exeption that line is not executed
return 0;
}
< /code>
Я моделирую ошибку в функции createSubtree (). < /p>
Во -первых, я называю Destruct (root), а затем бросаю исключение. Но таким образом, только поддерево будет разрушено.
Как уничтожить все дерево?

Подробнее здесь: https://stackoverflow.com/questions/797 ... gular-tree
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»