ধরুন আমাদের তিনটি স্ট্রিং টেক্সট আছে, w1 এবং w2। পাঠ্যটি বিভিন্ন শব্দ সহ একটি বাক্য। আমাদের পাঠ্যটিতে w1 এবং w2 এর যেকোনো দুটি ঘটনার মধ্যে সবচেয়ে ছোট দূরত্ব খুঁজে বের করতে হবে, দূরত্বটি তাদের মধ্যে শব্দের সংখ্যা দ্বারা পরিমাপ করা হয়। যদি w1 বা w2 টেক্সটে উপস্থিত না থাকে, তাহলে -1 রিটার্ন করুন।
সুতরাং, যদি ইনপুটটি টেক্সট ="আনন্দ সুখী শক্তি সুখী আনন্দের শক্তি সুখী সীমা" w1 ="শক্তি" w2 ="সীমা" এর মত হয়, তাহলে আউটপুট হবে 1, কারণ এর মধ্যে শুধুমাত্র একটি শব্দ "সুখী" আছে শক্তি এবং সীমা।
এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -
-
index1 :=null, index2 :=null
-
দূরত্ব :=999999
-
প্রতিটি সূচক আইডিএক্স এবং টেক্সটে শব্দ w এর জন্য, করুন
-
যদি w1 এর মত হয়, তাহলে
-
যদি index2 শূন্য না হয়, তাহলে
-
দূরত্ব :=সর্বনিম্ন দূরত্ব এবং (|idx - index2| - 1)
-
-
index1 :=idx
-
-
যদি w2 এর মত হয়, তাহলে
-
যদি index1 শূন্য না হয়, তাহলে
-
দূরত্ব :=সর্বনিম্ন দূরত্ব এবং (|idx - index1| - 1)
-
-
index2 :=idx
-
-
-
যদি index1 নাল না হয় এবং index2 নাল না হয়, তাহলে
-
ফেরত দূরত্ব
-
-
রিটার্ন -1
উদাহরণ
আসুন আরও ভালভাবে বোঝার জন্য নিম্নলিখিত বাস্তবায়ন দেখি
def solve(text, w1, w2):
index1 = None
index2 = None
distance = 2000000
for idx, word in enumerate(text.split(" ")):
if word == w1:
if index2 is not None:
distance = min(distance, abs(idx - index2) - 1)
index1 = idx
if word == w2:
if index1 is not None:
distance = min(distance, abs(idx - index1) - 1)
index2 = idx
if index1 is not None and index2 is not None:
return distance
return -1
text = "joy happy power happy joy joy power happy limit"
w1 = "power"
w2 = "limit"
print(solve(text, w1, w2)) ইনপুট
"joy happy power happy joy joy power happy limit", "power", "limit"
আউটপুট
1