-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdfs.py
40 lines (35 loc) · 1.33 KB
/
dfs.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
import time, sys
from ultis import *
"""class Node:
def __init__(self, data=(0, 0, 0, 0), prev_node=None, map=[], xo_objects_states={}, is_splitted=False):
if not ((data[0] < data[2]) or ((data[0] == data[2]) and data[1] < data[3])):
temp_data = (data[2], data[3], data[0], data[1])
self.data = temp_data
else:
self.data = data
self.prev_node = prev_node
self.map = map_copy(map)
self.xo_objects_states = dict(xo_objects_states)
self.is_splitted = is_splitted
def is_stand(self):
return self.data[0] == self.data[2] and self.data[1] == self.data[3]"""
def dfs(state):
current_state = Node
start = time.time()
nNode = 0
while len(state.states) != 0:
nNode += 1 # tinh tong so node phai tim kiem
current_state = state.states.pop(0)
state.set_player_position(current_state)
if state.check_goal():
break
state.add_valid_state(current_state, -120)
pointer = current_state
path = []
while pointer:
path.insert(0, pointer)
pointer = pointer.prev_node
mem = 0
if state.visited != []: mem += len(state.visited)*sys.getsizeof(state.visited[0])
if state.states != []: mem += len(state.states)*sys.getsizeof(state.states[0])
return path, nNode, mem