কম্পিউটার

C++-এ K দ্বারা বিভাজ্য সুবারে যোগফল


ধরুন আমাদের পূর্ণসংখ্যার একটি অ্যারে আছে। আমাদেরকে সংলগ্ন অ-খালি সাবয়ারের সংখ্যা খুঁজে বের করতে হবে, যেগুলির যোগফল k দ্বারা বিভাজ্য। যদি A =[4,5,0,-2,-3,1] এবং k =5 হয়, তাহলে আউটপুট হবে 7। সাতটি সাবয়ারে আছে। [[4,5,0,-2,-3,1], [5], [5,0], [5,0,-2,-3], [0], [0,-2,- 3], [-2,-3]]

এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -

  • একটি মানচিত্র m তৈরি করুন এবং m[0] কে 1 হিসাবে সেট করুন
  • temp :=0, ans :=0, এবং n :=অ্যারের আকার a
  • আমি 0 থেকে n – 1
      পরিসরে
    • temp :=temp + a[i]
    • x :=(temp mod k + k) mod k
    • উত্তর :=ans + m[x]
    • m[x] 1 দ্বারা বাড়ান
  • উত্তর ফেরত দিন

আরো ভালোভাবে বোঝার জন্য আসুন নিচের বাস্তবায়ন দেখি -

উদাহরণ

#include <bits/stdc++.h>
using namespace std;
class Solution {
   public:
   int subarraysDivByK(vector<int>& a, int k) {
      unordered_map <int, int> m;
      m[0] = 1;
      int temp = 0;
      int ans = 0;
      int n = a.size();
      for(int i = 0; i < n; i++){
         temp += a[i];
         int x = (temp % k + k) % k;
         ans += m[x];
         m[x]++;
      }
      return ans;
   }
};
main(){
   vector<int> v = {4,5,0,-2,-3,1};
   Solution ob;
   cout <<(ob.subarraysDivByK(v, 5));
}

ইনপুট

[4,5,0,-2,-3,1]
5

আউটপুট

7

  1. C++ এ সর্বাধিক যোগফল সার্কুলার সাবারে

  2. C++-এ সাবারের যোগফল K সমান

  3. C++ এ সর্বাধিক সাবয়ারের সমষ্টি m মডিউল

  4. C++ এ একটি সাবয়ারে ফ্লিপ করে 0 এর সংখ্যা সর্বাধিক করুন