ধরুন আমাদের একটি স্ট্রিং s এবং একটি অ-খালি স্ট্রিং p আছে, আমাদের s-এ p-এর অ্যানাগ্রামের সমস্ত সূচনা সূচক খুঁজে বের করতে হবে। স্ট্রিংগুলিতে শুধুমাত্র ছোট হাতের অক্ষর থাকে এবং s এবং p উভয় স্ট্রিংয়ের দৈর্ঘ্য 20 এবং 100 এর বেশি হবে না। সুতরাং উদাহরণস্বরূপ, যদি s:"cbaebabacd" p:"abc", তাহলে আউটপুট হবে [0, 6 ], ইনডেক্স 0 এ, এটি "cba", এবং আরেকটি হল "bac", এইগুলি হল "abc" এর অ্যানাগ্রাম৷
এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -
-
একটি মানচিত্র সংজ্ঞায়িত করুন m, n :=s এর আকার, বাম সেট করুন :=0, ডান :=0, কাউন্টার :=p এর আকার
-
একটি অ্যারে সংজ্ঞায়িত করুন ans
-
m
ম্যাপে p অক্ষরের ফ্রিকোয়েন্সি সংরক্ষণ করুন -
ডানের জন্য :=0 থেকে n – 1
-
যদি m এর s[সঠিক] থাকে এবং m[s[right]] শূন্য হয়, তাহলে m[s[right]] 1 দ্বারা কমান, কাউন্টার 1 দ্বারা হ্রাস করুন এবং কাউন্টার =0 হলে, উত্তরে বাম দিকে সন্নিবেশ করুন
-
অন্যথায়
-
যখন বাম <ডান,
-
যদি m এ s[left] না থাকে, তাহলে কাউন্টার 1 দ্বারা বাড়ান এবং m[s[left]] 1 দ্বারা বাড়ান
-
1 দ্বারা বাম বাড়ান
-
যদি m এর s[ডান] থাকে এবং m[s[ডান]] শূন্য হয়, তাহলে ডানদিকে 1 কমিয়ে লুপ থেকে বেরিয়ে আসুন
-
-
যদি m-এর কোনো s[left] না থাকে, তাহলে লেফট সেট করুন :=right + 1
-
-
-
উত্তর ফেরত দিন
উদাহরণ(C++)
আসুন আরও ভালোভাবে বোঝার জন্য নিচের বাস্তবায়ন দেখি −
#include <bits/stdc++.h> using namespace std; void print_vector(vector<auto> v){ cout << "["; for(int i = 0; i<v.size(); i++){ cout << v[i] << ", "; } cout << "]"<<endl; } class Solution { public: vector<int> findAnagrams(string s, string p) { map <char, int> m; int n = s.size(); int left = 0, right = 0; int counter = p.size(); vector <int> ans; for(int i = 0; i < p.size(); i++) m[p[i]]++; for(int right = 0; right < n; right++){ if(m.find(s[right]) != m.end() && m[s[right]]){ m[s[right]]--; counter--; if(counter == 0)ans.push_back(left); } else { while(left<right){ if(m.find(s[left]) != m.end()) { counter++; m[s[left]]++; } left++; if(m.find(s[right]) != m.end() && m[s[right]]){ right--; break; } } if(m.find(s[left])==m.end())left = right + 1; } } return ans; } }; main(){ Solution ob; print_vector(ob.findAnagrams("cbaebabacd", "abc")) ; }
ইনপুট
"cbaebabacd" "abc"
আউটপুট
[0, 6, ]