无法理解 Python 二维矩阵的输出
Cant understand the output of the Python 2D matrix
我正在尝试以螺旋格式打印值 1 到 9,如下所示:
[1,2,3]
[8,9,4]
[7,6,5]
但是,当我尝试通过 Python 脚本(如下所示)打印它时,它会覆盖它。我得到了正确的索引和值。我只是无法将值分配给正确的索引。脚本是:
n = 3
res = [[0]*n]*n
count = 1
def getcoord(r1,c1,r2,c2):
for c in range(c1, c2+1):
yield r1, c
for r in range(r1+1, r2+1):
yield r,c2
if r1 < r2 and c1 < c2:
for c in range(c2-1, c1-1, -1):
yield r2,c
for r in range(r2-1, r1, -1):
yield r, c1
r1 = 0
r2 = n-1
c1= 0
c2 = n-1
val = 1
while r1<=r2 and c1<=c2:
for r,c in getcoord(r1,c1,r2,c2):
print(r,c)
print("val", val)
res[r][c] = val
print("res", res)
val += 1
r1 += 1; r2 -= 1
c1 += 1; c2 -= 1
return res
当我尝试调试时,我得到如下输出:
(0, 0)
('val', 1)
('res', [[1, 0, 0], [1, 0, 0], [1, 0, 0]])
(0, 1)
('val', 2)
('res', [[1, 2, 0], [1, 2, 0], [1, 2, 0]])
(0, 2)
('val', 3)
('res', [[1, 2, 3], [1, 2, 3], [1, 2, 3]])
(1, 2)
('val', 4)
('res', [[1, 2, 4], [1, 2, 4], [1, 2, 4]])
(2, 2)
('val', 5)
('res', [[1, 2, 5], [1, 2, 5], [1, 2, 5]])
(2, 1)
('val', 6)
('res', [[1, 6, 5], [1, 6, 5], [1, 6, 5]])
(2, 0)
('val', 7)
('res', [[7, 6, 5], [7, 6, 5], [7, 6, 5]])
(1, 0)
('val', 8)
('res', [[8, 6, 5], [8, 6, 5], [8, 6, 5]])
(1, 1)
('val', 9)
('res', [[8, 9, 5], [8, 9, 5], [8, 9, 5]])
我在这里错过了什么?为什么我不能将正确的值分配给正确的索引,尽管它们都有?
提前致谢!
[0]*n
创建一个包含 3 个零的列表:[0, 0, 0]
.
然后,res = [[0]*n]*n
创建一个列表,您将其命名为 res
,其中包含我们刚刚在上面创建的 相同 列表的三倍。
因此,无论您是通过名称 res[0]
、res[1]
还是 res[2]
引用它,您总是访问相同的唯一列表。
执行 res[0][0] = 1
更新此列表的第一个元素,res[2][0] = 7
再次更新相同的元素。
当打印 res
时,您得到了同一个列表的三倍。
你想要的是三个不同的列表。您可以这样创建它们:
res = [[0]*n for i in range(n)]
我正在尝试以螺旋格式打印值 1 到 9,如下所示:
[1,2,3]
[8,9,4]
[7,6,5]
但是,当我尝试通过 Python 脚本(如下所示)打印它时,它会覆盖它。我得到了正确的索引和值。我只是无法将值分配给正确的索引。脚本是:
n = 3
res = [[0]*n]*n
count = 1
def getcoord(r1,c1,r2,c2):
for c in range(c1, c2+1):
yield r1, c
for r in range(r1+1, r2+1):
yield r,c2
if r1 < r2 and c1 < c2:
for c in range(c2-1, c1-1, -1):
yield r2,c
for r in range(r2-1, r1, -1):
yield r, c1
r1 = 0
r2 = n-1
c1= 0
c2 = n-1
val = 1
while r1<=r2 and c1<=c2:
for r,c in getcoord(r1,c1,r2,c2):
print(r,c)
print("val", val)
res[r][c] = val
print("res", res)
val += 1
r1 += 1; r2 -= 1
c1 += 1; c2 -= 1
return res
当我尝试调试时,我得到如下输出:
(0, 0)
('val', 1)
('res', [[1, 0, 0], [1, 0, 0], [1, 0, 0]])
(0, 1)
('val', 2)
('res', [[1, 2, 0], [1, 2, 0], [1, 2, 0]])
(0, 2)
('val', 3)
('res', [[1, 2, 3], [1, 2, 3], [1, 2, 3]])
(1, 2)
('val', 4)
('res', [[1, 2, 4], [1, 2, 4], [1, 2, 4]])
(2, 2)
('val', 5)
('res', [[1, 2, 5], [1, 2, 5], [1, 2, 5]])
(2, 1)
('val', 6)
('res', [[1, 6, 5], [1, 6, 5], [1, 6, 5]])
(2, 0)
('val', 7)
('res', [[7, 6, 5], [7, 6, 5], [7, 6, 5]])
(1, 0)
('val', 8)
('res', [[8, 6, 5], [8, 6, 5], [8, 6, 5]])
(1, 1)
('val', 9)
('res', [[8, 9, 5], [8, 9, 5], [8, 9, 5]])
我在这里错过了什么?为什么我不能将正确的值分配给正确的索引,尽管它们都有? 提前致谢!
[0]*n
创建一个包含 3 个零的列表:[0, 0, 0]
.
然后,res = [[0]*n]*n
创建一个列表,您将其命名为 res
,其中包含我们刚刚在上面创建的 相同 列表的三倍。
因此,无论您是通过名称 res[0]
、res[1]
还是 res[2]
引用它,您总是访问相同的唯一列表。
执行 res[0][0] = 1
更新此列表的第一个元素,res[2][0] = 7
再次更新相同的元素。
当打印 res
时,您得到了同一个列表的三倍。
你想要的是三个不同的列表。您可以这样创建它们:
res = [[0]*n for i in range(n)]