मान लीजिए कि हमारे पास तीन स्ट्रिंग टेक्स्ट हैं, w1, और w2। पाठ विभिन्न शब्दों वाला एक वाक्य है। हमें पाठ में w1 और w2 की किन्हीं दो घटनाओं के बीच सबसे छोटी दूरी ज्ञात करनी है, दूरी को उनके बीच शब्दों की संख्या में मापा जाता है। अगर टेक्स्ट में या तो w1 या w2 मौजूद नहीं है, तो -1 लौटाएं।
इसलिए, यदि इनपुट टेक्स्ट ="जॉय हैप्पी पावर हैप्पी जॉय पावर हैप्पी लिमिट" w1 ="पॉवर" w2 ="लिमिट" जैसा है, तो आउटपुट 1 होगा, क्योंकि बीच में केवल एक शब्द "हैप्पी" है। शक्ति और सीमा।
इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -
-
index1 :=null, index2 :=null
-
दूरी :=999999
-
पाठ में प्रत्येक अनुक्रमणिका idx और शब्द w के लिए, करें
-
अगर w, w1 के समान है, तो
-
अगर index2 शून्य नहीं है, तो
-
दूरी :=न्यूनतम दूरी और (|idx - index2| - 1)
-
-
index1 :=idx
-
-
अगर w, w2 के समान है, तो
-
यदि अनुक्रमणिका1 रिक्त नहीं है, तो
-
दूरी :=न्यूनतम दूरी और (|idx - index1| - 1)
-
-
index2 :=idx
-
-
-
यदि अनुक्रमणिका1 रिक्त नहीं है और अनुक्रमणिका2 रिक्त नहीं है, तो
-
वापसी की दूरी
-
-
वापसी -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