C++でxより大きいすべてのノードをリストから削除します
このチュートリアルでは、単一リンクリストからすべてのプライムノードを削除する方法を学習します。
問題を解決するための手順を見てみましょう。
-
データと次のポインタを使用して構造体を記述します。
-
ノードを単一リンクリストに挿入する関数を記述します。
-
ダミーデータを使用して、単一リンクリストを初期化します。
-
単一リンクリストを繰り返し処理します。現在のノードデータがxより大きいかどうかを確認します。
-
現在のデータがxより大きい場合は、ノードを削除します。
-
ノードを削除する関数を記述します。ノードを削除するときは、次の3つのケースを考慮してください。
-
ノードがヘッドノードの場合は、ヘッドを次のノードに移動します。
-
ノードが中間ノードの場合は、次のノードを前のノードにリンクします
-
ノードがエンドノードの場合は、前のノードリンクを削除します。
-
例
コードを見てみましょう。
#include <bits/stdc++.h> using namespace std; struct Node { int data; Node* next; }; Node* getNewNode(int data) { Node* newNode = new Node; newNode->data = data; newNode->next = NULL; return newNode; } void deleteGreaterNodes(Node** head_ref, int x) { Node *temp = *head_ref, *prev; if (temp != NULL && temp->data > x) { *head_ref = temp->next; free(temp); temp = *head_ref; } while (temp != NULL) { while (temp != NULL && temp->data <= x) { prev = temp; temp = temp->next; } if (temp == NULL) { return; } prev->next = temp->next; delete temp; temp = prev->next; } } void printLinkedList(Node* head) { while (head) { cout << head->data << " -> "; head = head->next; } } int main() { Node* head = getNewNode(1); head->next = getNewNode(2); head->next->next = getNewNode(3); head->next->next->next = getNewNode(4); head->next->next->next->next = getNewNode(5); head->next->next->next->next->next = getNewNode(6); int x = 3; cout << "Linked List before deletion:" << endl; printLinkedList(head); deleteGreaterNodes(&head, x); cout << "\nLinked List after deletion:" << endl; printLinkedList(head); return 0; }
出力
上記のプログラムを実行すると、次の結果が得られます。
Linked List before deletion: 1 -> 2 -> 3 -> 4 -> 5 -> 6 -> Linked List after deletion: 1 -> 2 -> 3 ->
結論
チュートリアルに質問がある場合は、コメントセクションにそのことを記載してください。
-
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. この問題を解決するために、ツリーをトラバースします。すべては、リーフノードに到達するレベルごとにすべて