C++の単一リンクリストからすべての非プライムノードを削除します
このチュートリアルでは、単一リンクリストからすべてのプライムノードを削除する方法を学習します。
問題を解決するための手順を見てみましょう。
-
データと次のポインタを使用して構造体を記述します。
-
ノードを単一リンクリストに挿入する関数を記述します。
-
ダミーデータを使用して、単一リンクリストを初期化します。
-
単一リンクリストを繰り返し処理します。現在のノードデータが素数であるかどうかを確認します。
-
現在のデータが素数でない場合は、ノードを削除します。
-
ノードを削除する関数を記述します。ノードを削除するときは、次の3つのケースを考慮してください。
-
ノードがヘッドノードの場合は、ヘッドを次のノードに移動します。
-
ノードが中間ノードの場合は、次のノードを前のノードにリンクします
-
ノードがエンドノードの場合は、前のノードリンクを削除します。
-
例
コードを見てみましょう。
#include <bits/stdc++.h> using namespace std; struct Node { int data; Node* next; }; void insertNode(Node** head_ref, int new_data) { Node* new_node = new Node; new_node->data = new_data; new_node->next = (*head_ref); (*head_ref) = new_node; } bool isPrime(int n) { if (n <= 1) { return false; } if (n <= 3) { return true; } if (n % 2 == 0 || n % 3 == 0) { return false; } for (int i = 5; i * i <= n; i = i + 6) { if (n % i == 0 || n % (i + 2) == 0) { return false; } } return true; } void deleteNonPrimeNodes(Node** head_ref) { Node* ptr = *head_ref; while (ptr != NULL && !isPrime(ptr->data)) { Node *temp = ptr; ptr = ptr->next; delete(temp); } *head_ref = ptr; if (ptr == NULL) { return; } Node *curr = ptr->next; while (curr != NULL) { if (!isPrime(curr->data)) { ptr->next = curr->next; delete(curr); curr = ptr->next; } else { ptr = curr; curr = curr->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, 5); insertNode(&head, 6); cout << "Linked List before deletion:" << endl; printLinkedList(head); deleteNonPrimeNodes(&head); cout << "\nLinked List after deletion:" << endl; printLinkedList(head); }
出力
上記のコードを実行すると、次の結果が得られます。
Linked List before deletion: 6 -> 5 -> 4 -> 3 -> 2 -> 1 -> Linked List after deletion: 5 -> 3 -> 2 ->
結論
チュートリアルに質問がある場合は、コメントセクションにそのことを記載してください。
-
C++の単一リンクリスト内のすべての素数ノードの積
n個のノードが与えられ、タスクはリンクリスト内のすべての素数ノードの積を出力することです。プライムノードは、カウント位置としてプライム値を持つノードです。 入力 10 20 30 40 50 出力 4,00,000 説明 − 10はプライムではないインデックス値1にあるため、スキップされます。素数であるインデックス値2で20に移動すると、考慮されます。同様に、40と50はプライムインデックスの場所にあります。 製品 − 20 * 40 * 50 =4,00,000 上の図で、赤い色のノードはプライムノードを表しています 以下で使用するアプローチは次のとおりです 一時
-
C++で特定のノードから距離kにあるすべてのノードを出力します
この問題では、二分木、ターゲットノード、整数Kが与えられます。ターゲットノードから距離Kにあるツリーのすべてのノードを印刷する必要があります。 。 二分木 は、各ノードに最大2つのノード(1つまたは2つ/なし)を持つ特別なツリーです。 問題を理解するために例を見てみましょう K =2 ターゲットノード:9 出力 − 5 1 3. 説明 − 距離は、ノードの上位、下位、または同じレベルで取得できます。したがって、それに応じてノードを返します。 この問題を解決するには、ターゲットノードからK距離離れたノードのタイプを理解する必要があります。 上記の試験から、k個の離