知行编程网知行编程网  2022-09-08 00:00 知行编程网 隐藏边栏  22 
文章评分 0 次,平均分 0.0
导语: 本文主要介绍了关于python里面有数组吗的相关知识,包括python字符串替代,以及array函数python这些编程知识,希望对大家有参考作用。

python中有数组吗?

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#中的值类型和引用类型,不知是否合适)。跟多学习内容,请点击

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写
扫一扫二维码分享