ধরুন আমাদের একটি স্ট্রিং s আছে, আমাদের s-এর সাবস্ট্রিংগুলিতে প্রশ্ন করতে হবে। প্রতিটি ক্যোয়ারী কোয়েরির জন্য [i], তিনটি অংশ আছে [বাম, ডান, কে], আমরা সাবস্ট্রিং s[বাম], ..., s[ডান] পুনর্বিন্যাস করতে পারি, এবং তারপর প্রতিস্থাপন করতে তাদের মধ্যে k পর্যন্ত বেছে নিতে পারি যেকোনো ছোট হাতের ইংরেজি অক্ষর। উপরে উল্লিখিত ক্রিয়াকলাপগুলির পরে যদি সাবস্ট্রিংটি প্যালিনড্রোম হওয়া সম্ভব হয় তবে প্রশ্নের ফলাফলটি সত্য। অন্যথায় মিথ্যা। আমাদের একটি অ্যারে উত্তর খুঁজতে হবে[], যেখানে উত্তর[i] হল i-th ক্যোয়ারী কোয়েরির ফলাফল[i]।
উদাহরণস্বরূপ, যদি ইনপুটটি "abcda" হয়, প্রশ্নগুলি [[3,3,0],[1,2,0],[0,3,1],[0,3,2],[0, 4,1]], তাহলে আউটপুট হবে [সত্য, মিথ্যা, মিথ্যা, সত্য, সত্য]
এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -
- সলভ নামক একটি পদ্ধতির সংজ্ঞা দিন, এটি dp ম্যাট্রিক্স এবং q নেবে। এটি নিচের মত কাজ করবে -
- l :=q[0], r :=q[1], k :=q[2], তারপর l এবং r 1 দ্বারা বাড়ান, one :=0
- আমি 0 থেকে 25 রেঞ্জের জন্য
- এক :=এক + (dp[r, i] – dp[l – 1, i]) মোড 2
- সত্য প্রত্যাবর্তন করুন, যখন এক / 2 <=k এর পূর্ণসংখ্যা ভাগ, অন্যথায় মিথ্যা
- makeDP() নামক আরেকটি পদ্ধতির সংজ্ঞা দিন, এটি dp ম্যাট্রিক্স এবং s নেবে, এটি নীচের মত কাজ করবে -
- আমি 0 থেকে s
- এর দৈর্ঘ্যের মধ্যে 0 থেকে 25 রেঞ্জের মধ্যে j-এর জন্য
- dp[i, j] :=dp[i – 1, j]
- dp[i, s[i]-এর ASCII - 'a'] এর ASCII 1 দ্বারা বাড়ান
- এর দৈর্ঘ্যের মধ্যে
- res[i] :=সমাধান(dp, q[i])
উদাহরণ(পাইথন)
আরো ভালোভাবে বোঝার জন্য নিচের বাস্তবায়নটি দেখি -
class Solution(object):
def solve(self,dp,q):
l = q[0]
r = q[1]
k = q[2]
r+=1
l+=1
#arr = [ 0 for i in range(26)]
one = 0
for i in range(26):
one += (dp[r][i]-dp[l-1][i])%2
return one//2<=k
def make_dp(self,dp,s):
for i in range(1,len(s)):
for j in range(26):
dp[i][j] = dp[i-1][j]
dp[i][ord(s[i])-ord('a')]+=1
def canMakePaliQueries(self, s, q):
n = len(s)
s = " "+s
dp = [[0 for i in range(26)] for j in range(n+1)]
self.make_dp(dp,s)
res = [False for i in range(len(q))]
for i in range(len(q)):
res[i] = self.solve(dp,q[i])
return res
ob = Solution()
print(ob.canMakePaliQueries("abcda", [[3,3,0],[1,2,0],[0,3,1],[0,3,2],[0,4,1]])) ইনপুট
"abcda" [[3,3,0],[1,2,0],[0,3,1],[0,3,2],[0,4,1]]
আউটপুট
[True, False, False, True, True]