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

C++の特定の位置にあるリンクリストノードを削除します


このチュートリアルでは、指定された位置にある単一リンクリストのノードを削除する方法を学習します。

問題を解決するための手順を見てみましょう。

  • データと次のポインタを使用して構造体を記述します。

  • ノードを単一リンクリストに挿入する関数を記述します。

  • ダミーデータを使用して、単一リンクリストを初期化します。

  • ノードを削除する位置を初期化します。

  • リンクリストを繰り返し処理し、指定された位置にあるノードを見つけて、ノードを削除します。

  • ノードを削除する関数を記述します。ノードを削除するときは、次の3つのケースを考慮してください。

    • ノードがヘッドノードの場合は、ヘッドを次のノードに移動します。

    • ノードが中間ノードの場合は、次のノードを前のノードにリンクします

    • ノードがエンドノードの場合は、前のノードリンクを削除します。

コードを見てみましょう

#include <bits/stdc++.h>
using namespace std;
struct Node {
   int data;
   struct Node *next;
};
void insertNode(struct Node** head_ref, int new_data) {
   struct Node* new_node = (struct Node*) malloc(sizeof(struct Node));
   new_node->data = new_data;
   new_node->next = (*head_ref);
   (*head_ref) = new_node;
}
void deleteNode(struct Node **head_ref, int position) {
   if (*head_ref == NULL) {
      return;
   }
   struct Node* temp = *head_ref;
   if (position == 1) {
      *head_ref = temp->next;
      free(temp);
      return;
   }
   for (int i = 2; temp != NULL && i < position - 1; i++) {
      temp = temp->next;
   }
   if (temp == NULL || temp->next == NULL) {
      return;
   }
   struct Node *next = temp->next->next;
   free(temp->next);
   temp->next = next;
}
void printLinkedList(struct Node *node) {
   while (node != NULL) {
      cout << node->data << "->";
      node = node->next;
   }
}
int main() {
   struct Node* head = NULL;
   insertNode(&head, 1);
   insertNode(&head, 2);
   insertNode(&head, 3);
   insertNode(&head, 4);
   insertNode(&head, 5);
   cout << "Linked list before deletion:" << endl;
   printLinkedList(head);
   deleteNode(&head, 1);
   cout << "\nLinked list after deletion:" << endl;
   printLinkedList(head);
   return 0;
}

出力

上記のプログラムを実行すると、次の結果が得られます。

Linked list before deletion:
5->4->3->2->1->
Linked list after deletion:
4->3->2->1->

結論

チュートリアルに質問がある場合は、コメントセクションにそのことを記載してください。


  1. C++でマルチレベルリンクリストをフラット化する

    この問題では、マルチレベルのリンクリストが提供されます。私たちの仕事は、マルチレベルのリンクリストをフラット化するプログラムを作成することです。 平坦化操作は、リンクリストで最初に第1レベルのノードが発生し、次に第2レベルのノードが発生するように実行されます。 マルチレベルリンクリスト は多次元データ構造であり、リンクリストのすべてのノードに2つのリンクポインタがあります。1つは次のノードへのリンクで、もう1つは1つ以上のノードを持つ子リストへのリンクです。この子ポインタは、他のリストノードを指している場合とそうでない場合があります。 例 問題を理解するために例を見てみましょう

  2. Pythonでリンクリストのノードを削除する

    いくつかの要素を持つリンクリストがあるとします。私たちのタスクは、リストから特定のノードを削除する関数を作成することです。したがって、リストが1→3→5→7→9のようで、3を削除すると、1→5→7→9になります。 削除するノードを指すポインタ「ノード」があるとすると、ノードを削除するにはこれらの操作を実行する必要があります- node.val =node.next.val node.next =node.next.next 例(Python) 理解を深めるために、次の実装を見てみましょう- class ListNode:    def __init__(se