কম্পিউটার

C++ এ প্রদত্ত অ্যারেতে থাকা স্বতন্ত্র জোড়ার সংখ্যা গণনা করুন


আমাদেরকে একটি অ্যারে দেওয়া হয়েছে, ধরা যাক, যে কোনো আকারের পূর্ণসংখ্যা মানের arr[] এবং কাজটি হল একটি প্রদত্ত অ্যারেতে উপলব্ধ স্বতন্ত্র জোড়ার সংখ্যা গণনা করা যার যোগফলও একই অ্যারেতে বিদ্যমান।

এক ধরণের ডেটা স্ট্রাকচার অ্যারে করে যা একই ধরণের উপাদানগুলির একটি নির্দিষ্ট-আকারের অনুক্রমিক সংগ্রহ সঞ্চয় করতে পারে। একটি অ্যারে ডেটা সংগ্রহের জন্য ব্যবহার করা হয়, তবে একই ধরণের ভেরিয়েবলের সংগ্রহ হিসাবে একটি অ্যারেকে ভাবতে প্রায়ই এটি বেশি কার্যকর।

মনে রাখার মতো পয়েন্ট

  • একটি জোড়াকে তাদের অর্ডার নির্বিশেষে একই উপাদানের সাথে একবার গণনা করা হবে। উদাহরণস্বরূপ, (3,2) এবং (2,3) 1 হিসাবে গণনা করা হবে।

  • যদি একটি অ্যারেতে একাধিকবার একটি সংখ্যা থাকে তবে এটি একটি জোড়া গঠনের জন্য ঠিক দুইবার বিবেচিত হবে। উদাহরণস্বরূপ, যদি একটি অ্যারেতে {2, 2, 2, 2} হিসাবে উপাদান থাকে তবে জোড়াটি হবে (2,2) এবং এটি 1 হিসাবে গণনা করা হবে।

উদাহরণস্বরূপ

Input − int arr = {6, 4, 10, 14}
Output − count is 2

ব্যাখ্যা − একটি অ্যারের যোগফলের সাথে জোড়া হল (6,4) এবং (10,4) তাই গণনা হল 2

Input − int arr = {6, 6, 6 ,6, 6, 13}
Output − count is 0

ব্যাখ্যা − একই অ্যারের যোগফলের সাথে একটি অ্যারেতে কোন জোড়া নেই। সুতরাং, গণনা 0।

নিম্নলিখিত প্রোগ্রামে ব্যবহৃত পদ্ধতি

  • একটি অ্যারে তৈরি করুন চলুন বলি, আরার[]

  • length() ফাংশন ব্যবহার করে একটি অ্যারের দৈর্ঘ্য গণনা করুন যা একটি অ্যারের উপাদান অনুযায়ী একটি পূর্ণসংখ্যা মান প্রদান করবে।

  • একটি অস্থায়ী পরিবর্তনশীল নিন যা উপাদানের গণনা সংরক্ষণ করবে।

  • একটি মানচিত্র টাইপ ভেরিয়েবল তৈরি করুন, আসুন mp

    বলি
  • স্টার্ট লুপ i থেকে 0 এবং i একটি অ্যারের আকারের চেয়ে কম

  • পেয়ার টাইপ ভেরিয়েবলের আরেকটি মানচিত্র তৈরি করুন, আসুন par বলি

  • স্টার্ট লুপ i থেকে 0 এবং i একটি অ্যারের আকারের চেয়ে কম

  • লুপের ভিতরে, j থেকে i+1 এবং j একটি অ্যারের আকারের চেয়ে কম দিয়ে আরেকটি লুপ শুরু করুন

  • লুপের ভিতরে, mp[arr[i]+arr[j]]> 0 এবং pr[{arr[i], arr[j] }] =0 কিনা তা পরীক্ষা করুন তারপর গণনা 1 দ্বারা বৃদ্ধি করুন

  • 1

    দ্বারা par[{ arr[i], arr[j] }] বৃদ্ধি
  • ইনক্রিমেন্ট par[{ arr[j], arr[i] }] 1

    দ্বারা
  • গণনা ফেরত দিন

  • ফলাফল প্রিন্ট করুন।

উদাহরণ

#include <iostream>
#include <map>
using namespace std;
// Returns number of pairs in ar[0..n-1] with
// sum equal to 'sum'
int countpairs(int ar[], int n){
   // Store counts of all elements in map m
   // to find pair (ar[i], sum-ar[i])
   // because (ar[i]) + (sum - ar[i]) = sum
   map<int, int> mymap;
   for (int i = 0; i < n; i++){
      mymap[ar[i]]++;
   }
   // To remove duplicate items we use result map
   map<pair<int, int>, int> p;
   int result = 0;
   // Considering all pairs
   for (int i = 0; i < n; i++){
      for (int j = i + 1; j < n; j++){
         // If sum of current pair exists
         if (mymap[ar[i] + ar[j]] > 0 && p[{ ar[i], ar[j] }] ==0){
            result++;
         }
         // Inserting the current pair both ways to avoid
         // duplicates.
         p[{ ar[i], ar[j] }]++;
         p[{ ar[j], ar[i] }]++;
      }
   }
   return result;
}
// main function
int main(){
   int ar[] = { 6, 4, 10, 14 };
   int n = sizeof(ar) / sizeof(ar[0]);
   cout << "count is "<<countpairs(ar, n);
   return 0;
}

আউটপুট

আমরা উপরের কোডটি চালালে আমরা নিম্নলিখিত আউটপুট পাব −

count is 2

  1. নোডগুলি গণনা করুন যার সমষ্টি X এর সাথে C++ এ একটি ফিবোনাচি সংখ্যা

  2. C++ এ K দ্বারা বিভাজ্য যোগফলের সংখ্যা সর্বাধিক করুন

  3. C++ এ একটি প্রদত্ত সংখ্যা K দ্বারা বিভাজ্য অ্যারের সমস্ত উপাদানের গুণফল

  4. C++ এ একটি অ্যারেতে বিভাজ্য জোড়া গণনা করুন