Cプログラミング
 Computer >> コンピューター >  >> プログラミング >> Cプログラミング

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


ツリーを削除するには、ツリーの各ノードをトラバースしてから、各ノードを削除する必要があります。これにより、ツリーのすべてのノードが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("\n 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("\n 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

  1. Pythonでn-aryツリーのコピーを作成するプログラム

    ルートが「ルート」に与えられているn-aryツリーが提供されたとします。完全なn-aryバイナリツリーのコピーを作成し、両方のツリーのプレオーダートラバーサルを実行する必要があります。コピーしたツリーは、別のルートノードを使用して保存する必要があります。ツリーのノード構造を以下に示します- Node:    value : <integer>    children : <array> したがって、入力が次のような場合 、出力はになります [14, 27, 32, 42, 56, 65] 入力ツリーと出力ツリーのプレオ

  2. Pythonでツリーの左端の最深ノードを見つけるプログラム

    二分木があるとしましょう。最も深いノードの値を見つける必要があります。最も深いノードが複数ある場合は、左端の最も深いノードを返します。 したがって、入力が次のような場合 4と7が最も深いが、4が最も残っているため、出力は4になります。 これを解決するには、次の手順に従います- queue:=1つのノードルートを持つキュー。 left_max:=ルートの値 キューのサイズが0より大きい場合は、実行してください level_size:=キューのサイズ 0からlevel_sizeの範囲のiの場合、実行 temp:=キューの最初の要素を削除します