用 C 语言编写一个程序,删除一个树


要删除一棵树,我们需要遍历该树的每个节点,然后删除其中每个节点。这样逐个删除树的每个节点,使之变为空。为此,我们需要使用一种从下到上遍历树的方法,以便我们可以先删除较低节点,再删除它们的父节点,这样就不会产生额外的复杂性。根据我们需要的条件,后序遍历将是最合适的,并且可以有效地发挥作用,因此我们的程序将是最优的。

以下树的后序遍历为 -

2-6-4-12-17-15

后序遍历单元格技术通过以下方式工作 -

检查左子节点→ 检查根节点→ 检查右子节点

示例

#include<stdio.h>
#include<stdlib.h>
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("
Node deleted, value is %d", node->data);    free(node); } int main() {    struct node *root = addnode(9);    root->left = addnode(4);    root->right = addnode(15);    root->left->left = addnode(2);    root->left->right = addnode(6);    root->right->left = addnode(12);    root->right->right = addnode(17);    nodedel(root);    root = NULL;    printf("
Tree deleted ");    return 0; }

输出

Node deleted, value is 4
Node deleted, value is 12
Node deleted, value is 17
Node deleted, value is 15
Node deleted, value is 9
Tree deleted

更新于: 09-Aug-2019

1K+ 浏览量

开启您的 职业生涯

通过完成课程获得认证

开始
广告