-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPractical_07(python).py
90 lines (73 loc) · 3.15 KB
/
Practical_07(python).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
'''
Experiment No. 7 : Write a python program for MAGIC SQUARE.
A magic square is an n*n matrix of the integers 1 to (n^2) such that the sum of each row,
column and diagonalis the same.
The figure given below is an example of the magic square for case n=5. In this example
the common sum is 65.
9 | 3 | 22 | 16 | 15 |
2 | 21 | 20 | 14 | 8 |
25 | 19 | 13 | 7 | 1 |
18 | 12 | 6 | 5 | 24 |
11 | 10 | 4 | 23 | 17 |
Conditions for placing the values in the matrix in appropriate manner (CIRCULAR ARRAY) :
1. The position of next number is calculated by decrementing row number of previous number by 1, and incrementing
the column number of previous number by 1. At any time, if the calculated row position becomes -1, it will wrap
around to n-1. Similarly, if the calculated column position becomes n, it will wrap around to 0.
2. If the magic square already contains a number at the calculated position, calculated column position will be
decremented by 2, and calculated row position will be incremented by 1.
3. If the calculated row position is -1 & calculated column position is n, the new position would be: (0, n-2).
'''
def generate_magic_square(size):
magic_square = [[0 for _ in range(size)] for _ in range(size)]
# Initializing first position of matrix
i = size // 2
j = size - 1
# Fill the magic square by placing values at appropriate positions
num = 1
while num <= (size * size):
if i == -1 and j == size: # 3rd Condition
j = size - 2
i = 0
else:
# next number goes out of right side of square
if j == size:
j = 0
# next number goes out of upper side
if i < 0:
i = size - 1
if magic_square[i][j]: # 2nd condition
j -= 2
i += 1
continue
else:
magic_square[i][j] = num
num += 1
j += 1
i -= 1 # 1st condition
# Printing the magic square
sum_row_column = size * (size * size + 1) // 2
print("Sum of each row or column is:", sum_row_column)
print("Magic Square of size", size, "*", size, "is:\n")
for i in range(size):
for j in range(size):
print(' %2d ' % (magic_square[i][j]), end=' | ')
# To display magic square in matrix form
if j == size - 1:
print()
def main():
flag = True
while flag:
n = int(input("\nEnter the size of the MAGIC SQUARE: "))
if n % 2 == 0:
s = int(input("Please enter an ODD Number (for example - 3, 5, 7, 9, ...): "))
generate_magic_square(s)
else:
generate_magic_square(n)
a = input("\nDo you want to print a Magic Square of some other size (yes/no): ")
if a == 'yes':
flag = True
else:
flag = False
print("\nThanks for using this program!")
if __name__ == "__main__":
main()