কম্পিউটার

C++ এ এককভাবে লিঙ্ক করা তালিকা থেকে সমস্ত প্রাইম নোড মুছুন


এই টিউটোরিয়ালে, আমরা শিখব কিভাবে একটি একক লিঙ্ক করা তালিকা থেকে সমস্ত প্রাইম নোড মুছে ফেলতে হয়।

আসুন সমস্যা সমাধানের পদক্ষেপগুলি দেখি৷

  • ডেটা এবং পরবর্তী পয়েন্টার দিয়ে struct লিখুন।

  • এককভাবে লিঙ্ক করা তালিকায় নোড সন্নিবেশ করার জন্য একটি ফাংশন লিখুন।

  • ডামি ডেটা দিয়ে এককভাবে লিঙ্ক করা তালিকা শুরু করুন।

  • এককভাবে লিঙ্ক করা তালিকার উপর পুনরাবৃত্তি করুন. বর্তমান নোড ডেটা প্রাইম কি না তা খুঁজুন৷

  • যদি বর্তমান ডেটা প্রাইম হয়, তাহলে নোড মুছে দিন।

  • নোড মুছে ফেলার জন্য একটি ফাংশন লিখুন। নোড মুছে ফেলার সময় নিম্নলিখিত তিনটি ক্ষেত্রে বিবেচনা করুন।

    • যদি নোডটি হেড নোড হয়, তাহলে মাথাটি পরবর্তী নোডে নিয়ে যান৷

    • যদি নোডটি মধ্যবর্তী নোড হয়, তাহলে পরবর্তী নোডটিকে আগের নোডের সাথে লিঙ্ক করুন

    • যদি নোডটি শেষ নোড হয়, তাহলে পূর্ববর্তী নোড লিঙ্কটি সরিয়ে দিন।

উদাহরণ

আসুন কোডটি দেখি।

#include <bits/stdc++.h>
using namespace std;
struct Node {
   int data;
   Node *next;
};
void insertNode(Node** head_ref, int new_data) {
   Node* new_node = (Node*)malloc(sizeof(struct 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 deleteNode(Node** head_ref, Node* del) {
   struct Node* temp = *head_ref;
   if (*head_ref == NULL || del == NULL) {
      return;
   }
   if (*head_ref == del) {
      *head_ref = del->next;
   }
   while (temp->next != del) {
      temp = temp->next;
   }
   temp->next = del->next;
   free(del);
   return;
}
void deletePrimeNodes(Node** head_ref) {
   Node* temp = *head_ref;
   Node* next;
   while (temp != NULL) {
      next = temp->next;
      if (isPrime(temp->data)) {
         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, 5);
   insertNode(&head, 6);
   cout << "Linked List before deletion:" << endl;
   printLinkedList(head);
   deletePrimeNodes(&head);
   cout << "\nLinked List after deletion:" << endl;
   printLinkedList(head);
}

আউটপুট

আপনি যদি উপরের প্রোগ্রামটি চালান, তাহলে আপনি নিম্নলিখিত ফলাফল পাবেন।

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

উপসংহার

টিউটোরিয়ালে আপনার কোন প্রশ্ন থাকলে মন্তব্য বিভাগে উল্লেখ করুন।


  1. C++ এ এককভাবে লিঙ্কযুক্ত তালিকায় সমস্ত প্রধান নোডের পণ্য

  2. C++ এ লিংকড লিস্ট র্যান্ডম নোড

  3. C++ এ প্রদত্ত নোড থেকে k দূরত্বে সমস্ত নোড প্রিন্ট করুন

  4. সার্কুলার সিঙ্গলি লিংকড লিস্ট বাস্তবায়নের জন্য C++ প্রোগ্রাম