Я работаю над проектом, который требует от меня реализовать алгоритм BFS с использованием Python, для которого я новичок.Алгоритм BFS в python
Алгоритм завершает выполнение головоломки 9 штук (3х3), но это требует очень большого количества времени, чтобы сделать это (5 минут):
def bfs(self):
fringe = deque([])
# start it
fringe.append(self.stateObj.getState())
while len(fringe) > 0:
state = fringe.popleft()
self.visited.append(state)
# just for tracing
# self.helper.drawBoard(state)
if self.stateObj.isCurrentStateGoalTest(state):
return True
for next_state in self.stateObj.getNextStates(state):
if (next_state not in (self.visited + list(fringe))):
fringe.append(next_state)
Кто-нибудь может указать на то, что я мог бы улучшить этот для достижения лучшей производительности? Любой практический ответ хорошо принят.