编写一个C编程程序来删除一棵树
要删除一棵树,我们需要遍历树的每个节点,然后逐个删除它们。这样一来,我们就可以逐个删除树的每个节点,使其变为空。为此,我们需要使用一种从底部向上遍历树的方法,这样我们就可以先删除较低的节点,然后再删除它们的父节点,以避免出现额外的复杂性。根据我们的需求,后序遍历是最适合的,并且能够高效地工作,使我们的程序达到最优。
以下树的后序遍历为 -
2-6-4-12-17-15登录后复制
检查左子节点 → 检查根节点 → 检查右子节点
示例
#include #include struct node { int data; struct node* left; struct node* right; }; struct node* addnode(int data) { struct node* node = (struct node*) malloc(sizeof(struct node)); node->data = data; node->left = NULL; node->right = NULL; return(node); } void nodedel(struct node* node) { if (node == NULL) return; nodedel(node->left); nodedel(node->right); printf("
Tree deleted "); return 0; }