Python中没有数组的数据结构,但列表很像数组,如:
a=[0,1,2],那么a[0]=0,a[1]=1,a[[2]=2,但是问题来了,就是如果要定义数组a怎么办作为 0 到 999?做?这可以通过 a = range(0, 1000) 来实现。或省略为 a = range(1000)。如果要定义长度为1000的a,初始值全为0,那么a = [0 for x in range(0, 1000)]
下面是二维数组的定义:
直接定义a=[[1,1],[1,1]],定义了一个2*2的二维数组,初始值为0。
间接定义 a=[[0 for x in range(10)] for y in range(10)],这里定义了10*10初始为0的二维数组。
还有更简单的字义二维数组的方法:
b = [[0]*10]*10,定义10*10初始为0的二维数组。
与a=[[0 for x in range(10)] for y in range(10)]比较:print a==b的结果为True。
但是,将a替换为b的定义方法后,之前可以正常运行的程序也出错了。仔细分析后得出区别:
a[0][0]=1时,只有a[0][0]为1,其他全为0。
b[0][0]=1时,a[0][0],a[1][0],只到a[9,0]全部为1。
这样,大数组中的10个小的一维数据都是同一个引用,即指向同一个地址。
故 b = [[0]*10]*10并不符合我们常规意义上的二维数组。
同时经过试验:c=[0]*10的定义与c=[0 for x in range(10)]有同样的效果,而没有上面相同引用的问题,估计数组c的定义时是值类型相乘,而前面b的用类型的相乘,因为一维数组是一个引用(借用C#中的值类型和引用类型,不知是否合适)。跟多学习内容,请点击
。
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ 如何安装python excel模块包?10/06
- ♥ python检查对象是否为空08/19
- ♥ python如何判断一个字符串是否包含空格?09/06
- ♥ python3类比功能好用吗?如何选择?01/13
- ♥ 如何使用python Mock库?01/06
- ♥ 如何在python3线程中使用Event?12/31
内容反馈