本文實例敘述了Python數組定義方法。分享給大家供大家參考,具體如下:
Python中沒有陣列的資料結構,但清單很像數組,如:
##
#這時: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)]
#下面是二維數組的定義:
直接定義:
#這裡定義了一個2*2的,且初始為0的二維陣列。
間接定義:
a=[[0 for x in range(10)] for y in range(10)]
登入後複製
這裡定義了10*10初始為0的二維陣列。
還有更簡單的字義二維陣列的方法:
定義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。
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數組定義方法詳細介紹相關文章請關注PHP中文網!