def transpose(matrix):
n=0
while n < (len(matrix)):
li = []
for sets in matrix:
li.append(sets[0])
n += 1
print(len(matrix))
return li
transpose([[1,2,3],[4,5,6],[7,8,9]])目前返回1,4,7名通缉犯[1,4,7,2,5,8,3,6,9]
发布于 2017-01-12 21:44:01
在自己的时间内有一个return语句,因此函数在到达这个点后会返回。您应该将您的返回降低到与时间相同的水平:
def transpose(matrix):
n = 0
li = []
while n < (len(matrix)):
...
return li您还可以将while循环和计数器n替换为在range(len(matrix))上迭代的for循环,这样您就可以安全地丢弃n,然后将li的初始化移到循环之外:
def transpose(matrix):
li = []
for i in range(len(matrix)):
inner_li = []
for sets in matrix:
inner_li.append(sets[i])
li.append(inner_li)
return li我建议您采用常用的转换矩阵的方法,以使代码更简洁:
def transpose(matrix):
return list(zip(*matrix))>>> transpose([[1,2,3],[4,5,6],[7,8,9]])
[(1, 4, 7), (2, 5, 8), (3, 6, 9)]发布于 2017-01-12 21:44:33
压痕很重要。另外,列表li是在错误的位置初始化的。
def transpose(matrix):
n=0
li = []
while n < (len(matrix)):
for sets in matrix:
li.append(sets[0])
n += 1
print(len(matrix))
return li发布于 2017-01-12 21:51:29
我想你知道这一点,但以防万一,这可以用numpy来完成。
import numpy as np
A = np.array([[1,2,3],[4,5,6],[7,8,9]])
print A.Thttps://stackoverflow.com/questions/41623481
复制相似问题