說明:本文並不詳細介紹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。
但用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中的陣列
說明 本文並不詳細介紹python中的列表,可以參看python文件。python中沒有陣列的資料結構,但列表很像陣列,如 a 0,1,2 這時a 0 0,a 1 1,a 2 2,但引出乙個問題,即如果陣列a想定義為0到999怎麼辦,這時可能通過a range 0,1000 實現。或省略為a ran...
python中陣列用法
如下 複製 a 0 a 1 但出果引用不存在的下標,則會引發異常。這時,你需要先新增元素,再引用就沒有問題 了。如果想預先保留空間,可以使用迴圈來給list,每個元素乙個預設值,再引用就不會有問題 了。如 這樣就生成了乙個100 100預設值為0的陣列。建立乙個寬度為3,高度為4的陣列 0,0,0 ...
Python中numpy陣列的合併
python中numpy陣列的合併有很多方法,如 np.concatenate np.stack np.hstack np.vstack np.dstack 其中最泛用的是第乙個和第二個。第乙個可讀性好,比較靈活,但是佔記憶體大。第二個則沒有記憶體占用大的問題。parameters introduc...