python二維數組
A. python里怎樣定義二維數組
直接定義就可以啊
xxx=[[1,2,3],[4,5,6],[7,8,9]]
B. python二維數組怎麼朝裡面填數據
你可以定義一個嵌套的list
表示一個二維數組,並初始化為這樣:
1
2
score = [[0]*3, [0]*3,[0]*3]
print score
這樣在循環外就能方便的訪問每個元素了。
C. python 如何實現將二維數組可視化
可以用tkinter畫圖實現 但要一些坐標計算
D. python 如何定義動態二維數組
追加字元串列表主要的二維列表。由於多維名單基本上列出清單,一個兩維的名單將代表一個單一的清單,其中包含其他列表。 .,因為Python列表是動態的,首先你可以使用「追加」功能容易添加和刪除其他列表:
E. python 二維數組讀入
最簡單的辦法:
a=["0001","0010","1100","1111"]
每個元素是一個字元串,比如
a[0]=="0001"
a[0][0]=="0" #表示「0001」字元串第一個字元是0
int(a[0][0])==0 #將字元串轉換為數字
或者就是二維:
a=[[0,0,0,1],[0,0,1,0],[1,1,0,0],[1,1,1,1]]
a[0][0]==0
方法有很多……
F. 如何在python3中輸入二維數組
也能輸入吧,用eval處理一下。
#-*-coding:utf8-*-
arrayString=input('輸入一個二維數組:')
array=eval(arrayString)
print(array)
輸入一個二維數組:[[1,2],[3,4]]
[[1, 2], [3, 4]]
G. python中二維數組中的數如何表達
python中是沒有數組的,只有列表(比如list=[1,2,3],二維的就是嵌套,比如list=[1,[1,2]])和字典(比如dic{1:2,3:4})
他們和數組組大的區別就是數組是有序的,而他們是無序的
H. python中如何使用二維數組
在Python中,一個像這樣的多維表格可以通過「序列的序列」實現。一個表格是行的序列。每一行又是獨立單元格的序列。這類似於我們使用的數學記號,在數學里我們用Ai,j,而在Python里我們使用A[i][j],代表矩陣的第i行第j列。
這看起來非常像「元組的列表」(Lists of Tuples)。
「列表的列表」示例:
我們可以使用嵌套的列表推導式(list comprehension)創建一個表格。 下面的例子創建了一個「序列的序列」構成的表格,並為表格的每一個單元格賦值。
table= [ [ 0 for i in range(6) ] for j in range(6) ]print tablefor d1 in range(6):for d2 in range(6):table[d1][d2]= d1+d2+2print table123456程序的輸出結果如下:
[[0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0]],
[[2, 3, 4, 5, 6, 7], [3, 4, 5, 6, 7, 8], [4, 5, 6, 7, 8, 9],
[5, 6, 7, 8, 9, 10], [6, 7, 8, 9, 10, 11], [7, 8, 9, 10, 11, 12]]
1234
這個程序做了兩件事:創建了一個6 × 6的全0表格。 然後使用兩枚骰子的可能組合的數值填充表格。 這並非完成此功能最有效的方式,但我們通過這個簡單的例子來演示幾項技術。我們仔細看一下程序的前後兩部分。
程序的第一部分創建並輸出了一個包含6個元素的列表,我們稱之為「表格」;表格中的每一個元素都是一個包含6個0元素的列表。它使用列表推導式,對於范圍從0到6的每一個j都創建對象。每一個對象都是一個0元素列表,由i變數從0到6遍歷產生。初始化完成之後,列印輸出二維全0表格。
推導式可以從里向外閱讀,就像一個普通表達式一樣。內層列表[ 0 for i in range(6) ]創建了一個包含6個0的簡單列表。外層列表[ [...] for j in range(6) ]創建了這些內層列表的6個深拷貝。
程序的第2個部分對2個骰子的每一個組合進行迭代,填充表格的每一個單元格。這由兩層嵌套循環實現,每一個循環迭代一個骰子。外層循環枚舉第一個骰子的所有可能值d1。內層循環枚舉第二個骰子d2。
更新每一個單元格時需要通過table[d1]選擇每一行;這是一個包含6個值的列表。這個列表中選定的單元格通過...[d2]進行選擇。我們將擲骰子的值賦給這個單元格,d1+d2+2。
其他示例:
列印出的列表的列表不太容易閱讀。下面的循環會以一種更加可讀的形式顯示表格。
for row in table:
print row[2, 3, 4, 5, 6, 7]
[3, 4, 5, 6, 7, 8]
[4, 5, 6, 7, 8, 9]
[5, 6, 7, 8, 9, 10]
[6, 7, 8, 9, 10, 11]
[7, 8, 9, 10, 11, 12]
12345678910111213作為練習,讀者可以試著在列印列表內容時,再列印出行和列的表頭。提示一下,使用"%2d" % value字元串運算符可以列印出固定長度的數字格式。顯示索引值(Explicit Index Values)。
我們接下來對骰子表格進行匯總統計,得出累計頻率表。我們使用一個包含13個元素的列表(下標從0到12)表示每一個骰子值的出現頻率。觀察可知骰子值2在矩陣中只出現了一次,因此我們期望fq[2]的值為1。遍歷矩陣中的每一個單元格,得出累計頻率表。
fq= 13 * [0]for i in range(6):for j in range(6):c= table[i][j]fq[ c ] += 112345使用下標i選出表格中的行,用下標j從行中選出一列,得到單元格c。然後用fq統計頻率。
這看起來非常的數學和規范。
Python提供了另外一種更簡單一些的方式。
使用列表迭代器而非下標,表格是列表的列表,可以採用無下標的for循環遍歷列表元素。
fq= 13 * [0]print fqfor row in table:for c in row:fq[c] += 1print fq[2:
I. 一個關於Python二維數組的問題
1. 先收集所有的非1"石頭"元素,到一個從小到大的有序堆heap中間..
Heap stonesToRemove=collectStones(stoneTable);
2. 以起始坐標(0,0)為首個「上一個坐標」,
prevPos=(0,0);
int sumSteps=0;
3. 在依次彈出堆中的元素,
For Each stone In stonesToRemove:
3.1. 測量逐個元素和上一個坐標的最小距離,並累加統計步數總和,,
sumSteps+=measurePosition(stone, prevPos)
prevPos=stone; 以當前石頭位置為新的上一位置.
4. 輸出總和..
return sumSteps;
-----------
我初步的想法,加了不能運行的偽代碼
J. Python如何對二維數組求和
Python對二維數組求和的方法:首先定義好一個二維數組;然後使用map函數對數組里每一個元素進行sum操作即可對二維數組求和。
關於二維數組求和的幾種方法:
a = [[1,2],[3,4],[5,6]]
方法一 sum(map(sum,a))
map(func,a) 函數是對a中的每一個元素進行sum操作
解釋一下map函數, map(fund, a) equals [func(i) for i in a] and return a list
方法二 sum(sum(i) for i in a)
方法三 sum(sum(a[i]) for i in range(len(a)))
方法四 rece(lambda x,y:x+y , rece(lambda x,y:x+y, a))
解釋一下rece(fun,a),rece返回的是一個結果值而不是一個list,第一步的時候是([1,2]+[3,4]) + [5,6]
得到一個[1,2,3,4,5,6], 然後進行的運算是(((((1+2)+3)+4)+5)+6) = 21
一般來說最常用的還是1和3這兩種方法,不知道map or rece, 一般都會採用3, 而知道的應該會採用1,比較簡潔。
推薦課程:Python核心基礎(尚矽谷)