您的位置:首页 > 编程语言 > Python开发

Python中利用列表推导式实现矩阵置换时发现的"问题"

2010-12-11 22:35 656 查看
新博客地址:http://gorthon.sinaapp.com/

在看cookbook中文第二版p154第4.8节《二维阵列变换》的时候,发现一个以前自己不是太在意的问题,虽然仔细想想应该能够得出结果,但是还是做个笔记以待备用。

>>> [[(i,j) for i in range(5)] for j in range(6,10)]

结果

[[(0, 6), (1, 6), (2, 6), (3, 6), (4, 6)], [(0, 7), (1, 7), (2, 7), (3, 7), (4, 7)], [(0, 8), (1, 8), (2, 8), (3, 8), (4, 8)], [(0, 9), (1, 9), (2, 9), (3, 9), (4, 9)]]

>>> [(i,j) for i in range(5) for j in range(6,10)]

结果

[(0, 6), (0, 7), (0, 8), (0, 9), (1, 6), (1, 7), (1, 8), (1, 9), (2, 6), (2, 7), (2, 8), (2, 9), (3, 6), (3, 7), (3, 8), (3, 9), (4, 6), (4, 7), (4, 8), (4, 9)]

可以看出这里两个for的运行顺序或者说哪个表示行哪个表示列。第二个例子与c++类似,而第一个例子由于用了[],所以先里面的推导再外面的推导,产生与c++相反的感觉。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: