এই টিউটোরিয়ালে, আমরা একটি প্রোগ্রাম লিখতে যাচ্ছি যেটি প্রদত্ত সাজানো বিন্যাসে অনুপস্থিত 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
উপসংহার
টিউটোরিয়ালে আপনার কোন প্রশ্ন থাকলে মন্তব্য বিভাগে উল্লেখ করুন।