কম্পিউটার

C++ এ স্ট্রিংগুলির একটি প্রদত্ত অ্যারেতে সমস্ত জোড়া অ্যানাগ্রাম প্রিন্ট করুন


এই সমস্যায়, আমাদের স্ট্রিংগুলির একটি অ্যারে দেওয়া হয়েছে এবং আমাদের সেই প্রদত্ত অ্যারের সমস্ত জোড়া অ্যানাগ্রাম প্রিন্ট করতে হবে৷

অ্যানাগ্রাম অন্য স্ট্রিং এর অক্ষর পুনর্বিন্যাস দ্বারা গঠিত হয় যে স্ট্রিং হয়. যেমন − hello এবং lolhe

সমস্যাটি বোঝার জন্য একটি উদাহরণ নেওয়া যাক -

Input: array = {“hello”, “hrdef”, “from”, “lohel”, “morf”}.
Output: [hello, lohel] , [from , morf]

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

উদাহরণ

চলুন সেই অ্যালগরিদম −

বাস্তবায়নের প্রোগ্রামটি দেখি
#include <iostream>
using namespace std;
#define NO_OF_CHARS 256
bool isAnagramString(string str1, string str2){
   int count[NO_OF_CHARS] = {0};
   int i;
   for (i = 0; str1[i] && str2[i]; i++){
      count[str1[i]]++;
      count[str2[i]]--;
   }
   if (str1[i] || str2[i])
      return false;
   for (i = 0; i < NO_OF_CHARS; i++)
      if (count[i])
         return false;
      return true;
}
void printAnagrams(string arr[], int n){
   for (int i = 0; i < n; i++)
      for (int j = i+1; j < n; j++)
         if (isAnagramString(arr[i], arr[j]))
            cout<<arr[i]<<" and "<<arr[j]<<" are anagrams.\n";
}
int main(){
   string arr[] = {"hello", "hrdef", "from", "lohel", "morf"};
   int n = sizeof(arr)/sizeof(arr[0]);
   printAnagrams(arr, n);
   return 0;
}

আউটপুট

hello and lohel are anagrams.
from and morf are anagrams.

এই সমাধান বুঝতে বেশ সহজ কিন্তু কম কার্যকরী। তাই কিছু অপ্টিমাইজেশন হতে পারে যা আমাদের সমাধানগুলিকে আরও কার্যকর করার জন্য তৈরি করা যেতে পারে। আমরা একটি স্ট্রিং ধারণকারী আমাদের অ্যারে সাজানোর দ্বারা এটি করতে পারেন. এই সাজানো অ্যারে অ্যানাগ্রামকে সহজ করে তুলবে।


  1. C++ এ প্রদত্ত যোগফল সহ সমস্ত জোড়া প্রিন্ট করুন

  2. C++ এ একটি স্ট্রিংয়ের সমস্ত প্যালিনড্রোম পারমুটেশন প্রিন্ট করুন

  3. একটি প্রদত্ত স্ট্রিং এর সমস্ত সাবস্ট্রিং C++ এ প্রিন্ট করার জন্য প্রোগ্রাম

  4. C++ এ স্ট্রিং এর অ্যারে