forked from HarshCasper/NeoAlgo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMatrix_Sort.py
70 lines (59 loc) · 1.66 KB
/
Matrix_Sort.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
def sort_matrix(mat, size):
'''
Takes input as unsorted matrix.
Creates a 1-d list of len size*size and values 0.
Sorts this list using python .sort() method.
Then assigns these values to the original matrix.
Parameters:
unsorted matrix mat
size of matrix
Returns a sorted matrix of dimension size x size
'''
temp_mat = [0]*(size*size)
count = 0
for i in range(size):
for j in range(size):
temp_mat[count] = mat[i][j]
count += 1
temp_mat.sort()
count = 0
for i in range(size):
for j in range(size):
mat[i][j] = temp_mat[count]
count += 1
return mat
def display_matrix(mat, size):
'''
Takes input a matrix and its size. Prints the value row wise of the matrix.
'''
for i in range(size):
for j in range(size):
print(mat[i][j], end=' ')
print()
if __name__ == '__main__':
size = int(input('Enter size: '))
mat = []
for i in range(size):
print(f'Enter all elements of row {i+1} separated by space: ', end='')
row = list(map(int, input().split()))
mat.append(row)
print('Before sorting: ')
display_matrix(mat, size)
mat = sort_matrix(mat, size)
print('After sorting: ')
display_matrix(mat, size)
# Sample Output
# Enter size: 3
# Enter all elements of row 1 separated by space: 8 3 5
# Enter all elements of row 2 separated by space: 9 1 2
# Enter all elements of row 3 separated by space: 4 7 6
# Before sorting:
# 8 3 5
# 9 1 2
# 4 7 6
# After sorting:
# 1 2 3
# 4 5 6
# 7 8 9
# time complexity = O(n^2log2(n))
# space complexity = O(n^2)