0
我之前在c#here中提出過這個問題,並且沒有真正做到這一點的簡潔方法。我現在正在嘗試在fsharp中做同樣的事情,看看結果如何。在f#中將相同長度的數組組合到一個2d數組中#
我有兩個相同長度和類型的數組,我想將它們組合成一個具有相同長度和2列的數組。我有這樣的代碼,這是否:
let twoDimensionalArray (arr1:array<'a>) (arr2:array<'a>) =
let rws = arr1|> Array.length
Array2D.init rws 1 (fun i j -> arr1.[i], arr2.[i])
說實話這讓我驚訝了一下,因爲我本來以爲應該在列維度這樣是2:
Array2D.init rws 2 (fun i j -> arr1.[i], arr2.[i])
但如果我更改爲2,然後我得到這個:
val it : (float * float) [,] = [[(1.0, 3.0); (1.0, 3.0)]
[(2.0, 4.0); (2.0, 4.0)]]
此數據:
let arr1 = [| 1.0; 2.0 |]
let arr2= [|3.0; 4.0 |]
爲什麼?
另外,我真的很想寫這更generacally,所以如果第一個數組有2列和第二個1,我得到一個3列矩陣等等。我試過這個:
let MultiArray (arr1:array<'a>) (arr2:array<'a>) =
let rws = arr1.Length
let c1 = arr1.GetLength(1)
let c2 = arr2.GetLength(1)
let cols = c1+c2
Array2D.init rws cols (fun i j -> arr1.[i], arr2.[i])
但這是有缺陷的。
您能否讓我知道我該怎麼做?此外,爲什麼我的第一個功能可行,但我認爲是錯誤的
謝謝
謝謝約翰!工作液:
let MultiArray (inp:float[][]) =
let cls = inp |> Array.length
let rows = inp.[0] |> Array.length
Array2D.init rows cls (fun i j -> inp.[j].[i])
樣本數據和使用:
let arr1 = [|1.0 ; 4.0; 6.0;5.;8.|]
let arr2= [|7.0; 8.0; 9.0;9.;10. |]
let inp = [| arr1; arr2; arr1|]
MultiArray inp;;
val it : float [,] = [[1.0; 7.0; 1.0]
[4.0; 8.0; 4.0]
[6.0; 9.0; 6.0]
[5.0; 9.0; 5.0]
[8.0; 10.0; 8.0]]
感謝約翰,我明白你的第一個點。但關於第二,我試圖創建2個不同的矩陣/矩陣,所以如何從arr1和arr2創建inp:float [] []? – nik
@nik - '[| arr1; arr2 |]' –
尷尬簡單... :) – nik