ধরুন আমাদের পূর্ণসংখ্যার একটি অ্যারে আছে। আমাদেরকে সংলগ্ন অ-খালি সাবয়ারের সংখ্যা খুঁজে বের করতে হবে, যেগুলির যোগফল 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