কম্পিউটার

C++ এ উভয় পাশে জোড় বা বিজোড় সংখ্যার একই গণনা সহ অ্যারে সূচক


এখানে আমরা একটা সমস্যা দেখব, ধরুন একটা অ্যারে দেওয়া হল। n উপাদান আছে. আমাদের এমন একটি সূচক খুঁজে বের করতে হবে, যেখানে এর বাম দিকের জোড় সংখ্যার কম্পাঙ্ক এবং ডান পাশের জোড় সংখ্যার কম্পাঙ্ক একই, অথবা এর বাম দিকের বিজোড় সংখ্যার কম্পাঙ্ক ডানদিকের বিজোড় সংখ্যার কম্পাঙ্কের সমান। যদি এমন কোন ফলাফল না থাকে তবে -1 ফেরত দিন।

ধরুন অ্যারেটি {4, 3, 2, 1, 2, 4} এর মতো। আউটপুট হল 2। সূচী 2-এর উপাদান হল 2, এটির বামে শুধুমাত্র একটি বিজোড় সংখ্যা রয়েছে এবং এর ডানদিকে একটি মাত্র বিজোড় সংখ্যা রয়েছে।

এই সমস্যা সমাধানের জন্য, আমরা বাম এবং ডান তথ্য সংরক্ষণ করার জন্য জোড়ার দুটি ভেক্টর তৈরি করব। বাম দিকের ভেক্টর তার বাম পাশের বিজোড় এবং জোড় সংখ্যার ফ্রিকোয়েন্সি সংরক্ষণ করবে এবং ডানের ভেক্টর ডান পাশের জন্য একই কাজ করবে। যদি বাম এবং ডানের জন্য জোড় গণনা বা বাম এবং ডানের জন্য বিজোড় গণনা একই হয়, তাহলে সূচকটি ফেরত দিন।

অ্যালগরিদম

getIndex(arr, n) -

Begin
   define odd and even, and initialize as 0
   define left_vector, right_vector for odd even pairs
   add (odd, even) into left_vector
   for i in range 0 to n-1, do
      if arr[i] is even, then increase even, otherwise increase odd
         add (odd, even) into left_vector
   done
   odd := 0 and even := 0
   add (odd, even) into right_vector
   for i in range n-1 down to 1, do
      if arr[i] is even, then increase even, otherwise increase odd
         add (odd, even) into right_vector
   done
   reverse the right_vector
   for each element at index i in left_vector, do
      if left_vector[i].first = right_vector[i].first, or left_vector[i].odd= right_vector[i].odd, then return i
   done
   return -1
End

উদাহরণ

#include <iostream>
#include <vector>
#include <utility>
#include <algorithm>
using namespace std;
int getIndex(int n, int arr[]) {
   int odd = 0, even = 0;
   vector<pair<int, int >> left_vector, right_vector;
   left_vector.push_back(make_pair(odd, even));
   for (int i = 0; i < n - 1; i++) { //count and store odd and even frequency for left side
      if (arr[i] % 2 == 0)
         even++;
      else
         odd++;
      left_vector.push_back(make_pair(odd, even));
   }
   odd = 0, even = 0;
   right_vector.push_back(make_pair(odd, even)); //count and store odd and even frequency for right side
   for (int i = n - 1; i > 0; i--) {
      if (arr[i] % 2 == 0)
         even++;
      else
         odd++;
      right_vector.push_back(make_pair(odd, even));
   }
   reverse(right_vector.begin(), right_vector.end());
   for (int i = 0; i < left_vector.size(); i++) {
      if (left_vector[i].first == right_vector[i].first ||
         left_vector[i].second == right_vector[i].second)
      return i;
   }
   return -1;
}
int main() {
   int arr[] = {4, 3, 2, 1, 2};
   int n = sizeof(arr) / sizeof(arr[0]);
   int index = getIndex(n, arr);
   if(index == -1) {
      cout << "-1";
   } else {
      cout << "index : " << index;
   }
}

আউটপুট

index : 2

  1. C++ এ অনন্য সংখ্যার সাথে সংখ্যা গণনা করুন

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

  3. উভয় পাশে জোড় বা বিজোড় সংখ্যার একই গণনা সহ অ্যারে সূচকের জন্য C++ প্রোগ্রাম?

  4. C++ প্রোগ্রাম যোগফল এবং গুণফল উভয়ই N এর মতো একই সহ দুটি সংখ্যা খুঁজে বের করতে