ধরুন আমাদের একটি 2D বোর্ড এবং শব্দের একটি তালিকা আছে। তাই অভিধান থেকে বোর্ডের সব শব্দ খুঁজে বের করতে হবে। এখানে প্রতিটি শব্দকে ক্রমানুসারে সংলগ্ন কক্ষের অক্ষর থেকে তৈরি করতে হবে, যেখানে সংলগ্ন কোষগুলি অনুভূমিকভাবে বা উল্লম্বভাবে প্রতিবেশী। আমাদের মনে রাখতে হবে যে একই অক্ষর ঘর একটি শব্দে একবারের বেশি ব্যবহার করা যাবে না।
তাই যদি ইনপুট −
এর মত হয়এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -
-
একটি অ্যারে ফলাফল তৈরি করুন
-
সমাধান() নামক একটি পদ্ধতির সংজ্ঞা দিন, এটি বোর্ড, d, i, j s
লাগবে -
যখন i বা j যথাক্রমে বোর্ড সারি এবং কলাম পরিসরে না থাকে, তখন মিথ্যা ফেরত দিন
-
l :=বোর্ড[i, j]
-
যদি d-এ l উপস্থিত থাকে, তাহলে
-
d :=d[l], s এর সাথে l সংযুক্ত করুন
-
যদি # d-এ থাকে এবং d[#] শূন্য না হয়, তাহলে
-
ফলাফলে s ঢোকান
-
সেট d[#] :=0
-
-
বোর্ড[i, j] :=*
-
যদি i+1 <বোর্ড এবং বোর্ডে সারির সংখ্যা [i + 1, j] d তে, তাহলে
-
কল সমাধান (বোর্ড, ডি, আই + 1, জে, এস)
-
-
যদি j+1 <বোর্ডে কলামের সংখ্যা এবং বোর্ডে [i, j+1] d, তাহলে
-
কল সমাধান (বোর্ড, ডি, আই, জে+1, এস)
-
-
যদি i-1> 0 এবং বোর্ড [i - 1, j] d তে থাকে, তাহলে
-
কল সমাধান (বোর্ড, ডি, আই - 1, জে, এস)
-
-
যদি d-এ j-1> 0 এবং বোর্ড[i, j-1] হয়, তাহলে
-
কল সল্ভ (বোর্ড, ডি, আই, জে-১, এস)
-
-
বোর্ড[i, j] :=l
-
-
insert() নামক একটি পদ্ধতি সংজ্ঞায়িত করুন, এটি শব্দ এবং অভিধান টি
নেবে -
বর্তমান :=t
-
আমি শব্দে
-
যদি আমি কারেন্টে না থাকি, তাহলে বর্তমান[i] :=নতুন মানচিত্র
-
বর্তমান :=বর্তমান[i]
-
-
বর্তমান [#] :=1
-
প্রধান পদ্ধতি থেকে নিম্নলিখিতগুলি করুন -
-
একটি মানচিত্র তৈরি করুন t
-
শব্দে শব্দের জন্য:insert(word, t)
কল করুন -
প্রতিটি কক্ষের জন্য i, j বোর্ডে − কল সল্ভ (বোর্ড, t, i, j)
-
ফেরত ফলাফল
উদাহরণ
আরো ভালোভাবে বোঝার জন্য আসুন নিচের বাস্তবায়ন দেখি -
class Solution(object):
def findWords(self, board, words):
self.result = []
t = {}
for word in words:
self.insert(word,t)
for i in range(len(board)):
for j in range(len(board[0])):
self.solve(board,t,i,j)
return self.result
def solve(self,board,d,i,j,s=""):
if i<0 or j<0 or i>=len(board) or j>=(len(board[0])):
return
l = board[i][j]
if l in d:
d = d[l]
s+=l
if "#" in d and d['#']:
self.result.append(s)
d['#'] = 0
board[i][j] = '*'
if i+1<len(board) and board[i+1][j] in d :
self.solve(board,d,i+1,j,s)
if j+1 < len(board[0]) and board[i][j+1] in d:
self.solve(board,d,i,j+1,s)
if i-1>=0 and board[i-1][j] in d :
self.solve(board,d,i-1,j,s)
if j-1>=0 and board[i][j-1] in d :
self.solve(board,d,i,j-1,s)
board[i][j] = l
def insert(self, word,t):
current = t
for i in word:
if i not in current:
current[i] = {}
current =current[i]
current['#']=1
ob = Solution()
print(ob.findWords([["o","a","a","n"],["e","t","e","a"],["i","h","k", "r"],["i","f","l","v"]],["oath","pea","tea","rain"])) ইনপুট
[["o","a","a","n"], ["e","t","e","a"], ["i","h","k","r"], ["i","f","l","v"]], ["oath","pea","tea","rain"]
আউটপুট
['oath', 'tea']