কম্পিউটার

একটি অ্যারেতে ন্যূনতম সংখ্যা যোগ করুন যাতে যোগফল C++ এ সমান হয়?


ধরুন কিছু সংখ্যা সহ একটি অ্যারে আছে। উপাদানগুলির যোগফলকে সমান করতে এটির সাথে সর্বনিম্ন কতগুলি সংখ্যা যোগ করা হবে তা আমাদের বলতে হবে। সংখ্যাটি অবশ্যই 0-এর বেশি হতে হবে। তাই উপাদানগুলির যোগফল যদি বিজোড় হয়, তাহলে আমরা 1 যোগ করব, কিন্তু যোগফল যদি ইতিমধ্যেই জোড় হয়, তাহলে আমরা এটিকে জোড় করার জন্য 2 যোগ করব।

অ্যালগরিদম

addMinNumber(arr)

begin
   s := 0
   for each element e from arr, do
      s := e + s
   done
   if s is even, then return 2, otherwise 1
end

উদাহরণ

#include<iostream>
using namespace std;
int addMinNumber(int arr[], int n) {
   int sum = 0;
   for(int i = 0; i<n; i++) {
      sum += arr[i];
   }
   return (sum % 2)? 1 : 2;
}
main() {
   int arr[] = {5, 8, 4, 7, 5};
   int n = sizeof(arr)/sizeof(arr[0]);
   cout << "Minimum " << addMinNumber(arr, n) << " should be added";
}

আউটপুট

Minimum 1 should be added

  1. C++ ব্যবহার করে যোগফল হিসেবে N প্রকাশ করতে ন্যূনতম সংখ্যক প্যালিনড্রোম প্রয়োজন।

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

  3. C++ ব্যবহার করে অ্যারেটিকে ভালো করার জন্য ন্যূনতম সংখ্যক উপাদান সরানো উচিত।

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