-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwaterjugproblem.py
96 lines (90 loc) · 2.67 KB
/
waterjugproblem.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
# 3 water jugs capacity -> (x,y,z) where x>y>z
# initial state (12,0,0)
# final state (6,6,0)
capacity = (12,8,5)
# Maximum capacities of 3 jugs -> x,y,z
x = capacity[0]
y = capacity[1]
z = capacity[2]
# to mark visited states memory is a dictionarycontaining key value pair.
memory = {}
# store solution path
ans = []
def get_all_states(state):
# Let the 3 jugs be called a,b,c
a = state[0]
b = state[1]
c = state[2]
if(a==6 and b==6):
ans.append(state)
return True
# if current state is already visited earlier
if((a,b,c)in memory):
return False
memory[(a,b,c)] = 1
#empty jug a
if(a>0):
#empty a into b
if(a+b<=y):
if(get_all_states((0,a+b,c)) ):
ans.append(state)
return True
else:
if( get_all_states((a-(y-b), y, c)) ):
ans.append(state)
return True
#empty a into c
if(a+c<=z):
if(get_all_states((0,b,a+c))):
ans.append(state)
return True
else:
if( get_all_states((a-(z-c),b,z)) ):
ans.append(state)
return True
#empty jug b
if(b>0):
#empty b into a
if(a+b<=x):
if(get_all_states((a+b,0,c)) ):
ans.append(state)
return True
else:
if(get_all_states((x,b-(x-a),c)) ):
ans.append(state)
return True
#empty b into c
if(b+c<=z):
if get_all_states((a, 0, b+c)):
return True
else:
if(get_all_states((a,b-(z-c),z)) ):
ans.append(state)
return True
#empty jug c
if(c>0):
#empty c into a
if(a+c<=x):
if(get_all_states((a+c,b,0))):
ans.append(state)
return True
else:
if(get_all_states((x,b,c-(x-a)))):
ans.append(state)
return True
#empty c into b
if(b+c<=y):
if(get_all_states((a,b+c,0)) ):
ans.append(state)
return True
else:
if(get_all_states((a,y,c-(y-b))) ):
ans.append(state)
return True
return False
initial_state = (12,0,0)
print("Starting work...\n")
get_all_states(initial_state)
ans.reverse()
for i in ans:
print(i)