অ্যারে − একটি অ্যারে হল একই ডেটা টাইপের উপাদানগুলির একটি ধারক, যার উপাদানগুলি 0 সূচীযুক্ত৷
এই সমস্যায়, আমরা পূর্ণসংখ্যার একটি অ্যারে ব্যবহার করব। এবং সমস্ত উপাদান প্রদত্ত সংখ্যার চেয়ে বড় কিনা তা পরীক্ষা করুন। এখানে আমরা পরীক্ষা করব যে অ্যারের সমস্ত উপাদান একটি প্রদত্ত সংখ্যা k এর থেকে বড় বা সমান। যদি না হয় তাহলে আমরা অ্যারের দুটি ন্যূনতম উপাদান যোগ করব এবং এই যোগফলটিকে একক উপাদান হিসাবে বিবেচনা করব। এবং তারপর আবার নতুন অ্যারের জন্য একই অবস্থার জন্য পরীক্ষা করুন. যদি শর্তটি সত্য বলে বেরিয়ে আসে তবে যোগফলটি কতবার সম্পাদিত হয়েছে তা ফেরত দেওয়া হবে।
Array = { 2, 6,3,12, 7} K = 5 Output : 1
ব্যাখ্যা − প্রথমে আমরা পরীক্ষা করব যে সমস্ত উপাদানগুলি k এর থেকে বড় বা না। যেহেতু তারা নয় আমরা দুটি ন্যূনতম সংখ্যা যোগ করব। যেটি 2 এবং 3 তাই আমাদের নতুন অ্যারের প্রথম উপাদানটি 5 হবে। এখন, আবার আমরা পরীক্ষা করব, এইবার শর্তটি পূরণ হয়েছে তাই আমরা নং রিটার্ন করব। সংযোজন আমরা করেছি।
অ্যালগরিদম
ইনপুট - অ্যারে এবং কে
Step 1 : check if all elements are greater than or equal to K Step 2: if(yes){ Print number of iterations. } exit(0) Step 3: else { Add smallest two elements of the array and make it one element. } Step 4: goto step 1
উদাহরণ
#include<bits/stdc++.h> using namespace std; class MinHeap{ int *harr; int capacity; int heap_size; public: MinHeap(int *arr, int capacity); void heapify(int ); int parent(int i){ return (i-1)/2; } int left(int i){ return (2*i + 1); } int right(int i){ return (2*i + 2); } int extractMin(); int getMin(){ return harr[0]; } int getSize(){ return heap_size; } void insertKey(int k); }; MinHeap::MinHeap(int arr[], int n){ heap_size = n; capacity = n; harr = new int[n]; for (int i=0; i<n; i++) harr[i] = arr[i]; for (int i=n/2-1; i>=0; i--) heapify(i); } void MinHeap::insertKey(int k){ heap_size++; int i = heap_size - 1; harr[i] = k; while (i != 0 && harr[parent(i)] > harr[i]){ swap(harr[i], harr[parent(i)]); i = parent(i); } } int MinHeap::extractMin(){ if (heap_size <= 0) return INT_MAX; if (heap_size == 1){ heap_size--; return harr[0]; } int root = harr[0]; harr[0] = harr[heap_size-1]; heap_size--; heapify(0); return root; } void MinHeap::heapify(int i){ int l = left(i); int r = right(i); int smallest = i; if (l < heap_size && harr[l] < harr[i]) smallest = l; if (r < heap_size && harr[r] < harr[smallest]) smallest = r; if (smallest != i){ swap(harr[i], harr[smallest]); heapify(smallest); } } int main(){ int arr[] = { 2, 6,3,12, 7}; int n = sizeof(arr)/sizeof(arr[0]); int k = 5; MinHeap h(arr, n); long int res = 0; while (h.getMin() < k){ if (h.getSize() == 1) return -1; int first = h.extractMin(); int second = h.extractMin(); h.insertKey(first + second); res++; } cout << res; return 0; }
আউটপুট
1