ধরুন আমাদের একটি ছোট হাতের স্ট্রিং s এবং আরেকটি মান k আছে। এখন একটি অপারেশন বিবেচনা করুন যেখানে আমরা অ্যাকাউন্ট এবং অক্ষর হিসাবে বারবার ধারাবাহিক অক্ষর রেখে একটি স্ট্রিং-এ একটি রান-দৈর্ঘ্য এনকোডিং করি। সুতরাং স্ট্রিং যদি "aaabbc" এর মতো হয় তবে "3a2bc" হিসাবে এনকোড করা হবে। এখানে আমরা "c" এর জন্য "1c" রাখি না কারণ এটি শুধুমাত্র একবার পরপর প্রদর্শিত হয়। তাই আমরা প্রথমে s-তে যেকোন k-পরপর অক্ষর মুছে ফেলতে পারি, তারপর ফলাফল রান-লেংথেনকোডিংয়ের সম্ভাব্য ন্যূনতম দৈর্ঘ্য খুঁজে বের করতে পারি।
সুতরাং, যদি ইনপুটটি s ="xxxxxyyxxxxxzzxxx", k =2 এর মত হয়, তাহলে আউটপুট হবে 6, কারণ দুটি সুস্পষ্ট পছন্দ হল "yy" বা "zz" s অপসারণ করা। যদি আমরা "yy" s মুছে ফেলি, তাহলে আমরা "10x2z3x" পাব যার দৈর্ঘ্য 7। যদি আমরা "zz" s মুছে ফেলি, তাহলে "5x2y8x" পাব যার দৈর্ঘ্য 6, এটি সবচেয়ে ছোট।
এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -
-
একটি ফাংশন calc_cost() সংজ্ঞায়িত করুন। এটি l
লাগবে -
যদি l 0 এর সমান হয়, তাহলে
-
রিটার্ন 0
-
-
যদি l 1 এর মত হয়, তাহলে
-
রিটার্ন 1
-
-
অন্যথায়,
-
str(l) + 1
এর রিটার্ন সাইজ
-
-
একটি ফাংশন উপসর্গ () সংজ্ঞায়িত করুন। এটি s
লাগবে-
pre :=একটি তালিকা প্রাথমিকভাবে জোড়া সহ [0, 0]
-
শেষ :=শূন্য
-
প্রতিটি c-এর জন্য s, করুন
-
যদি c শেষের মত হয়, তাহলে
-
একটি জোড়া সন্নিবেশ করান (প্রাকের শেষ আইটেমের 0 তম উপাদান, 1 + পূর্বের শেষ আইটেমের 1 ম উপাদান) প্রি
-
-
অন্যথায়,
-
সন্নিবেশ করান (প্রি-এর শেষ আইটেমের 0ম উপাদান) + calc_cost(প্রি-এর শেষ আইটেমের প্রথম উপাদান, 1) প্রি
-
-
শেষ :=c
-
-
প্রত্যাবর্তন পূর্ব
-
-
প্রধান পদ্ধতি থেকে নিম্নলিখিতগুলি করুন:
-
pre :=উপসর্গ(গুলি)
-
suf :=উপসর্গের বিপরীত (গুলি বিপরীত ক্রমে)
-
উত্তর :=অসীম
-
i এর জন্য 0 থেকে s - k + 1 এর আকার, do
-
j :=i + k
-
জোড়া (বাম, মধ্য) :=পূর্ব[i]
-
জোড়া (ডান, মধ্য) :=সুফ[জে]
-
খরচ :=বাম + ডান
-
c1 :=s[i - 1] যদি i> 0 অন্যথায় শূন্য
-
c2 :=s[j] যদি j
-
যদি c1 হয় c2 এর মতো, তাহলে
-
খরচ :=খরচ + calc_cost(midl + midr)
-
-
অন্যথায়,
-
খরচ :=খরচ + calc_cost(midl) + calc_cost(midr)
-
-
উত্তর :=সর্বনিম্ন উত্তর এবং খরচ
-
-
উত্তর ফেরত দিন
আরো ভালোভাবে বোঝার জন্য আসুন নিচের বাস্তবায়ন দেখি -
উদাহরণ
def calc_cost(l): if l == 0: return 0 if l == 1: return 1 else: return len(str(l)) + 1 class Solution: def solve(self, s, k): def prefix(s): pre = [[0, 0]] last = None for c in s: if c == last: pre.append([pre[-1][0], pre[-1][1] + 1]) else: pre.append([pre[-1][0] + calc_cost(pre[-1][1]),1]) last = c return pre pre = prefix(s) suf = prefix(s[::-1])[::-1] ans = float("inf") for i in range(len(s) - k + 1): j = i + k left, midl = pre[i] right, midr = suf[j] cost = left + right c1 = s[i - 1] if i > 0 else None c2 = s[j] if j < len(s) else None if c1 == c2: cost += calc_cost(midl + midr) else: cost += calc_cost(midl) + calc_cost(midr) ans = min(ans, cost) return ans ob = Solution() s = "xxxxxyyxxxxxzzxxx" print(ob.solve(s, 2))
ইনপুট
s = "xxxxxyyxxxxxzzxxx"
আউটপুট
6