-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoneDimension.py
39 lines (29 loc) · 1.46 KB
/
oneDimension.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
import gridgenerator
def countClusters(grid):
clusterCount = 0
sizeOfCluster = {}
modifiedGrid = [1 if x else 0 for x in grid]
print("\nThe matrix you have entered is:\n\t{0}\n\nStarting labelling...".format(modifiedGrid))
for i in range(len(grid)):
# If the site isn't occupied, we can simply continue to the next one.
if not grid[i]:
continue
# From this point on, the site at index 'i' is necessarily occupied.
# The first scenario is when the first site is occupied and thus, starts a cluster, the first cluster.
if i == 0:
clusterCount += 1
sizeOfCluster[clusterCount] = 1
continue
# This is the second scenario wherein, the previous site is occupied and thus, this is not a new cluster.
if grid[i-1] == 1:
sizeOfCluster[clusterCount] += 1
modifiedGrid[i] = modifiedGrid[i-1]
continue
# In the final senario, the site [i] starts an entirely new cluster.
# No condition check is required since the control flow is sure to have reached there only as a last resort.
clusterCount += 1
sizeOfCluster[clusterCount] = 1
modifiedGrid[i] = clusterCount
print("Labelling complete. The matrix is now:\n\t{0}\n\nEncountered {1} clusters of sizes as follows:\n\t{2}".format(modifiedGrid, clusterCount, sizeOfCluster))
print("\n")
delay = input("Press enter to continue... ")