Ich habe diese zwei Versionen eines Programms, das ein magisches Quadrat ungerader Ordnung erzeugt.
1. Verwenden von Numpy-Arrays:
import numpy as np
N = 5
magic_square = np.zeros((N, N), dtype=int)
n = 1
i, j = 0, N // 2
while n <= N ** 2:
magic_square[i, j] = n
n += 1
newi, newj = (i - 1) % N, (j + 1) % N
if magic_square[newi, newj]:
i += 1
else:
i, j = newi, newj
print(magic_square)
2. Listen verwenden
N = 5
magic_square = [[0] * N] * N
n = 1
i, j = 0, N // 2
while n <= N ** 2:
magic_square[i][j] = n
n += 1
newi, newj = (i - 1) % N, (j + 1) % N
if magic_square[newi][newj]:
i += 1
else:
i, j = newi, newj
print(magic_square)
Aber derjenige, der Listen verwendet, gibt einen IndexError: Listenindex außerhalb des Bereichs für die Zeile magic_square [i] [j] = n
Gibt es einen Unterschied bei der Indizierung für np-Arrays und -Listen?
Wenn ja, wie korrigiere ich dann den Code, der Listen enthält?
Wie von hpaulj erwähnt, nicht verwenden [[0]*N]*N]
>>> l = [[0]*5]*5
[[0, 0, 0, 0, 0],
[0, 0, 0, 0, 0], # same as above list
[0, 0, 0, 0, 0], # same as above list
[0, 0, 0, 0, 0], # same as above list
[0, 0, 0, 0, 0]] # same as above list
>>> l[0][0] = 5
[[5, 0, 0, 0, 0],
[5, 0, 0, 0, 0],
[5, 0, 0, 0, 0],
[5, 0, 0, 0, 0],
[5, 0, 0, 0, 0]]
Verwenden
magic_square = [[0 for i in range(N)] for i in range(N)]
Dieser Artikel stammt aus dem Internet. Bitte geben Sie beim Nachdruck die Quelle an.
Bei Verstößen wenden Sie sich bitte [email protected] Löschen.
Lass mich ein paar Worte sagen