ツリーを削除する C プログラミング プログラムを作成する

WBOY
リリース: 2023-08-26 14:45:05
転載
1091 人が閲覧しました

ツリーを削除するには、ツリーの各ノードをたどって、1 つずつ削除する必要があります。このようにして、ツリーの各ノードを 1 つずつ削除し、空にすることができます。これを行うには、ツリーを下から上に走査するメソッドを使用して、最初に下位のノードを削除し、次にその親を削除して、さらなる複雑さを回避する必要があります。ニーズに基づいて、ポストオーダー トラバーサルが最も適しており、プログラムを最適化するために効率的に機能します。

次のツリーの事後探索は -

2-6-4-12-17-15
ログイン後にコピー

事後探索セル テクノロジは次のように機能します:

左の子ノードを確認する→ルートを確認するノード→右側の子ノードを確認します

ツリーを削除する C プログラミング プログラムを作成する

#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("</p><p> 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("</p><p> 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
ログイン後にコピー

以上がツリーを削除する C プログラミング プログラムを作成するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:tutorialspoint.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート