কম্পিউটার

C++ ব্যবহার করে সাজানো অ্যারেতে k-এর চেয়ে বড় উপাদানের সংখ্যা খুঁজুন


এই সমস্যায়, আমাদেরকে একটি অ্যারে দেওয়া হয়েছে যা এন সাজানো পূর্ণসংখ্যার মান এবং একটি পূর্ণসংখ্যা k নিয়ে গঠিত। আমাদের কাজ হল একটি সাজানো অ্যারেতে k-এর থেকে বড় উপাদানের সংখ্যা খুঁজে বের করা।

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

ইনপুট

arr[] = {1, 2, 5, 7, 8, 9} k = 4

আউটপুট

4

ব্যাখ্যা

Elements greater than k = 4 are
5, 7, 8, 9

সমাধান পদ্ধতি

সমস্যার একটি সহজ সমাধান হল 0 থেকে N পর্যন্ত অ্যারের উপর একটি লুপ ব্যবহার করে। এবং তারপর k-এর থেকে বড় প্রথম উপাদানটিতে থামুন। তারপর অবশিষ্ট মানের সংখ্যা গণনা করুন।

উদাহরণ

আমাদের সমাধানের কাজ চিত্রিত করার জন্য প্রোগ্রাম

#include <iostream>
using namespace std;
int findGreaterCount(int arr[], int n, int k){
   for(int i = 0; i < n; i++){
      if(arr[i] > k)
         return (n - i);
   }
   return -1;
}
int main(){
   int arr[] = { 1, 3, 5, 7, 7, 8, 12, 21};
   int n = sizeof(arr) / sizeof(arr[0]);
   int k = 5;
   cout<<"The number of elements greater than k is "<<findGreaterCount(arr, n, k);
   return 0;
}

আউটপুট

The number of elements greater than k is 5

উপরের কোডটি ভাল কাজ করে কিন্তু প্রোগ্রামের সময় জটিলতা হল O(N)।

আরেকটি আরও কার্যকর পদ্ধতি হল k-এর থেকে বড় উপাদানগুলি খুঁজে বের করতে বাইনারি অনুসন্ধান ব্যবহার করা। এবং তারপর বৃহত্তর উপাদানের গণনা ফেরত দিন।

উদাহরণ

আমাদের সমাধানের কাজ চিত্রিত করার জন্য প্রোগ্রাম

#include <iostream>
using namespace std;
int findGreaterCount(int arr[], int n, int k){
   int s = 0;
   int e = n - 1;
   int firstGreterEle = n;
   while (s <= e) {
      int mid = s + (e - s) / 2;
      if (arr[mid] > k) {
         firstGreterEle = mid;
         e = mid - 1;
      }
      else
         s = mid + 1;
   }
   return (n - firstGreterEle);
}
int main(){
   int arr[] = { 1, 3, 5, 7, 7, 8, 12, 21};
   int n = sizeof(arr) / sizeof(arr[0]);
   int k = 5;
   cout<<"The number of elements greater than k is "<<findGreaterCount(arr, n, k);
   return 0;
}

আউটপুট

The number of elements greater than k is 5

  1. C++ এ ধারাবাহিক উপাদানগুলির XOR ব্যবহার করে অ্যারের উপাদানগুলি খুঁজুন

  2. C++ ব্যবহার করে অ্যারের সমস্ত উপাদান মুছে ফেলার জন্য ন্যূনতম সংখ্যক অপারেশন প্রয়োজন।

  3. C++ ব্যবহার করে একটি অ্যারের মধ্যে একটি সংখ্যার ফ্রিকোয়েন্সি খুঁজুন।

  4. C++ এ রোটেটেড সর্টেড অ্যারেতে রোটেশন কাউন্ট খুঁজুন