python數組定義

轉自:https://blog.csdn.net/minsenwu/article/details/7872679數組

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)].net

下面是二維數組的定義:
直接定義 a=[[1,1],[1,1]],這裏定義了一個2*2的,且初始爲0的二維數組。
間接定義 a=[[0 for x in range(10)] for y in range(10)],這裏定義了10*10初始爲0的二維數組。
還有更簡單的字義二維數組的方法:blog

b = [[0]*10]*10,定義10*10初始爲0的二維數組。引用

與a=[[0 for x in range(10)] for y in range(10)]比較:print a==b的結果爲True。程序

但用b的定義方法代替a後,之前的能夠正常運行的程序也出錯了,通過仔細分析得出區別:方法

a[0][0]=1時,只有a[0][0]爲1,其餘全爲0。nw

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#中的值類型和引用類型,不知是否合適)。

相關文章
相關標籤/搜索