首頁  >  文章  >  後端開發  >  Python數組定義方法詳細介紹

Python數組定義方法詳細介紹

高洛峰
高洛峰原創
2017-03-06 14:01:492153瀏覽

本文實例敘述了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。

但用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中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn