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 deleteSmallerNodes(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);
deleteSmallerNodes(&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: 12 -> 11 -> 10 ->
結論
チュートリアルに質問がある場合は、コメントセクションにそのことを記載してください。
-
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. この問題を解決するために、ツリーをトラバースします。すべては、リーフノードに到達するレベルごとにすべて