কম্পিউটার

C++ এ একটি সাজানো না করা অ্যারেতে k-th অনুপস্থিত উপাদান


এই টিউটোরিয়ালে, আমরা একটি প্রোগ্রাম লিখতে যাচ্ছি যেটি প্রদত্ত সাজানো বিন্যাসে অনুপস্থিত k-th উপাদান খুঁজে বের করে।

k-th খুঁজুন প্রদত্ত সাজানো বিন্যাসে সর্বনিম্ন থেকে সর্বোচ্চ পর্যন্ত অনুপস্থিত সংখ্যা। আসুন সমস্যা সমাধানের পদক্ষেপগুলি দেখি৷

  • বিন্যস্ত বিন্যাস শুরু করুন।
  • একটি সেটে সমস্ত উপাদান সন্নিবেশ করান।
  • অ্যারে থেকে সর্বোচ্চ এবং সর্বনিম্ন উপাদান খুঁজুন।
  • একটি লুপ লিখুন যা মিনিট থেকে সর্বোচ্চ পর্যন্ত পুনরাবৃত্তি করে এবং গণনার জন্য একটি পরিবর্তনশীল বজায় রাখুন।
    • যদি বর্তমান উপাদান সেটটিতে উপস্থিত থাকে, তাহলে গণনা বৃদ্ধি করুন।
    • যদি গণনা k এর সমান হয়, তাহলে i ফেরত দিন।

উদাহরণ

আসুন কোডটি দেখি।

#include <bits/stdc++.h>
using namespace std;
int findMissingNumber(int arr[], int n, int k) {
   unordered_set<int> numbers;
   int count = 0;
   for (int i = 0; i < n; i++) {
      numbers.insert(arr[i]);
   }
   int max = *max_element(arr, arr + n);
   int min = *min_element(arr, arr + n);
   for (int i = min + 1; i < max; i++) {
      if (numbers.find(i) == numbers.end()) {
         count++;
      }
      if (count == k) {
         return i;
      }
   }
   return -1;
}
int main() {
   int arr[] = { 1, 10, 3, 2, 5 }, n = 5;
   int k = 3;
   cout << findMissingNumber(arr, n, k) << endl;
   return 0;
}

আউটপুট

আপনি যদি উপরের কোডটি চালান, তাহলে আপনি নিম্নলিখিত ফলাফল পাবেন।

7

উপসংহার

টিউটোরিয়ালে আপনার কোন প্রশ্ন থাকলে মন্তব্য বিভাগে উল্লেখ করুন।


  1. C++ এ একটি অ্যারে বিপরীত করুন

  2. C++ এ M বার সংযুক্ত একটি অ্যারে থেকে K-th ন্যূনতম উপাদান খুঁজুন

  3. C++-এ একটি সাজানো না করা অ্যারেতে k নিকটতম সংখ্যাগুলি খুঁজুন

  4. C++-এ অ্যারের প্রতিটি উপাদানের সারপাসার কাউন্ট খুঁজুন