C++で指定された値より大きい二重リンクリストからすべてのノードを削除します
このチュートリアルでは、二重リンクリストからすべてのプライムノードを削除する方法を学習します。
問題を解決するための手順を見てみましょう。
-
データ、前のポインタ、次のポインタを使用して構造体を記述します。
-
ノードを二重リンクリストに挿入する関数を記述します。
-
ダミーデータを使用して二重リンクリストを初期化します。
-
二重にリンクされたリストを繰り返し処理します。現在のノードデータが指定された値より大きいかどうかを確認します。
-
現在のデータが指定された値より大きい場合は、ノードを削除します。
-
ノードを削除する関数を記述します。ノードを削除するときは、次の3つのケースを考慮してください。
-
ノードがヘッドノードの場合は、ヘッドを次のノードに移動します。
-
ノードが中間ノードの場合は、次のノードを前のノードにリンクします
-
ノードがエンドノードの場合は、前のノードリンクを削除します。
-
例
コードを見てみましょう。
#include <bits/stdc++.h> using namespace std; struct Node { int data; Node *prev, *next; }; void insertNode(Node** head_ref, int new_data) { Node* new_node = (Node*)malloc(sizeof(struct Node)); new_node->data = new_data; new_node->prev = NULL; new_node->next = (*head_ref); if ((*head_ref) != NULL) { (*head_ref)->prev = new_node; } (*head_ref) = new_node; } void deleteNode(Node** head_ref, Node* del) { if (*head_ref == NULL || del == NULL) { return; } if (*head_ref == del) { *head_ref = del->next; } if (del->next != NULL) { del->next->prev = del->prev; } if (del->prev != NULL) { del->prev->next = del->next; } free(del); return; } void deleteGreaterNode(Node** head_ref, int K) { Node* temp = *head_ref; Node* next; while (temp != NULL) { next = temp->next; if (temp->data > K) { deleteNode(head_ref, temp); } temp = next; } } void printLinkedList(Node* head) { while (head != NULL) { cout << head->data << " -> "; head = head->next; } } int main() { Node* head = NULL; insertNode(&head, 1); insertNode(&head, 2); insertNode(&head, 3); insertNode(&head, 4); insertNode(&head, 10); insertNode(&head, 11); insertNode(&head, 12); int K = 10; cout << "Linked List before deletion:" << endl; printLinkedList(head); deleteGreaterNode(&head, K); cout << "\nLinked List after deletion:" << endl; printLinkedList(head); }
出力
上記のプログラムを実行すると、次の結果が得られます。
Linked List before deletion: 12 -> 11 -> 10 -> 4 -> 3 -> 2 -> 1 -> Linked List after deletion: 10 -> 4 -> 3 -> 2 -> 1 ->
結論
チュートリアルに質問がある場合は、コメントセクションにそのことを記載してください。
-
C++で特定のノードから距離kにあるすべてのノードを出力します
この問題では、二分木、ターゲットノード、整数Kが与えられます。ターゲットノードから距離Kにあるツリーのすべてのノードを印刷する必要があります。 。 二分木 は、各ノードに最大2つのノード(1つまたは2つ/なし)を持つ特別なツリーです。 問題を理解するために例を見てみましょう K =2 ターゲットノード:9 出力 − 5 1 3. 説明 − 距離は、ノードの上位、下位、または同じレベルで取得できます。したがって、それに応じてノードを返します。 この問題を解決するには、ターゲットノードからK距離離れたノードのタイプを理解する必要があります。 上記の試験から、k個の離
-
C++でリーフノードから距離kにあるすべてのノードを出力します
この問題では、二分木と数Kが与えられます。葉のノードからkの距離にある木のすべてのノードを印刷する必要があります。 二分木 は、各ノードに最大2つのノード(1/2 /なし)がある特別なツリーです。 リーフノード 二分木のは、ツリーの最後にあるノードです。 この問題では、リーフノードからの距離はリーフノードよりも高いレベルのノードです。レベル4のリーフノードから距離2のノードがレベル2になるとします。 問題を理解するために例を見てみましょう K =2 出力 − 6 9. この問題を解決するために、ツリーをトラバースします。すべては、リーフノードに到達するレベルごとにすべて