কম্পিউটার

C++ এ সাজানো তালিকা II থেকে সদৃশগুলি সরান


ধরুন আমাদের কিছু উপাদানের তালিকা আছে। আমরা একাধিকবার ঘটেছে যে সমস্ত উপাদান অপসারণ করতে হবে. তাই শুধুমাত্র স্বতন্ত্র উপাদান তালিকায় থাকবে। সুতরাং যদি তালিকাটি [1,1,1,2,2,3,5,6,6,7,8] এর মত হয়, তবে আউটপুট হবে [3,5,7,8], অন্যান্য সমস্ত উপাদান উপস্থিত রয়েছে একাধিকবার।

আসুন ধাপগুলো দেখি -

  • মান -1, পূর্ববর্তী :=NULL, dummyPtr :=ডামি সহ একটি ডামি নোড তৈরি করুন
  • যদিও হেড শূন্য নয়
    • যদি হেডের পরবর্তী উপস্থিত থাকে বা হেডের মান পরবর্তী নোডের মানের সমান না হয়, তাহলে
      • ডামিপিটিআরের পাশে :=হেড
      • temp :=মাথার পাশে, এবং হেডের পরেরটি শূন্য করুন
      • মাথা :=টেম্প
      • dummyPtr :=dummyPtr এর পরবর্তী
    • অন্যথায়
      • prev :=head, এবং head :=head এর পরের
      • যখন হেড শূন্য নয় এবং হেডের মান =পূর্বের মান
        • পূর্ববর্তী :=মাথা এবং মাথা :=মাথার পরের দিকে
  • ডামির পরেরটি ফেরত দিন

আরো ভালোভাবে বোঝার জন্য আসুন নিচের বাস্তবায়ন দেখি -

উদাহরণ

#include <bits/stdc++.h>
using namespace std;
class ListNode{
   public:
      int val;
      ListNode *next;
      ListNode(int data){
         val = data;
         next = NULL;
      }
   };
   ListNode *make_list(vector<int> v){
      ListNode *head = new ListNode(v[0]);
      for(int i = 1; i<v.size(); i++){
         ListNode *ptr = head;
         while(ptr->next != NULL){
            ptr = ptr->next;
         }
         ptr->next = new ListNode(v[i]);
      }
      return head;
   }
   void print_list(ListNode *head){
      ListNode *ptr = head;
      cout << "[";
      while(ptr){
      cout << ptr->val << ", ";
      ptr = ptr->next;
   }
   cout << "]" << endl;
}
class Solution {
   public:
   ListNode* deleteDuplicates(ListNode* head) {
      ListNode* dummy = new ListNode(-1);
      ListNode* prev = NULL;
      ListNode* dummyPtr = dummy;
      ListNode* nextNode;
      while(head){
         if(!head->next || head->val != head->next->val){
            dummyPtr->next = head;
            ListNode* temp = head->next;
            head->next = NULL;
            head = temp;
            dummyPtr = dummyPtr->next;
         } else {
            prev = head;
            head = head->next;
            while(head && head->val == prev->val){
               prev = head;
               head = head->next;
            }
         }
      }
   return dummy->next;
   }
};
main(){
   Solution ob;
   vector<int> v = {1,1,1,2,2,3,5,6,6,7,8};
   ListNode *head = make_list(v);
   print_list(ob.deleteDuplicates(head));
}

ইনপুট

[1,1,1,2,2,3,5,6,6,7,8]

আউটপুট

[3, 5, 7, 8, ]

  1. পাইথনে একটি তালিকা থেকে ডুপ্লিকেটগুলি কীভাবে সরানো যায়

  2. অ্যান্ড্রয়েডে বাছাই করা লিঙ্ক তালিকা থেকে ডুপ্লিকেটগুলি কীভাবে সরিয়ে ফেলা যায়?

  3. C++ এ হেড পয়েন্টার ছাড়াই লিঙ্ক করা তালিকা থেকে একটি নোড মুছুন

  4. C++ এ সাজানো এবং ঘোরানো লিঙ্ক তালিকায় ঘূর্ণন গণনা করুন