-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBanker's Algorithm.py
51 lines (42 loc) · 1.38 KB
/
Banker's Algorithm.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
def check(i):
for j in range(m):
if need[i][j] > available[j]:
return False
return True
n = int(input("Enter the number of Processes: "))
m = int(input("Enter the number of Resources: "))
allocation = []
for i in range(n):
allocation.append(list(map(int, input('\nEnter the number of instances allocated for Process P'+str(i)+" : ").strip().split())))
maX = []
for i in range(n):
maX.append(list(map(int, input("\nEnter Max matrix entry for Process P"+str(i)+" : ").strip().split())))
available = list(map(int, input("\nEnter the number of instances available of Resources : ").strip().split()))
# Compute the need matrix
need = [[0 for i in range(m)] for j in range(n)]
for i in range(n):
for j in range(m):
need[i][j] = maX[i][j] - allocation[i][j]
# Implements Banker's Algorithm
sequence = ['0']*n
visited = [0]*n
count = 0
while count<n:
safe = False
for i in range(n):
if visited[i]==0 and check(i):
sequence[count] = "P" + str(i)
count += 1
visited[i] = 1
safe = True
for j in range(m):
available[j] += allocation[i][j]
if not safe:
break
if (count<n):
print("The System is Unsafe!")
else:
print()
print("The System is Safe!")
print("Safe Sequence is", sequence)
print("Available resource is", available)