有一个矩阵转置功能:
let rec transpose = function
| (_::_)::_ as M -> List.map List.head M :: transpose (List.map List.tail M)
| _ -> []
[[1; 2; 3]; [4; 5; 6]; [7; 8; 9]] |> transpose |> printfn "%A"
Run Code Online (Sandbox Code Playgroud)
它工作正常.
是什么(_ :: _):: _什么意思?
我不明白整个代码!
谁能解释一下?
谢谢!
我找到了答案:
(_ :: _):: _是匹配int类型列表的值的模式
如果我写:
let rec transpose (M:int list list) =
match M with
| hd::tl -> List.map List.head M :: transpose (List.map List.tail …
Run Code Online (Sandbox Code Playgroud) 假设我有一系列序列,例如
{1, 2, 3}, {1, 2, 3}, {1, 2, 3}
Run Code Online (Sandbox Code Playgroud)
什么是旋转或拉链这个序列的最佳方法,所以我反而拥有,
{1, 1, 1}, {2, 2, 2}, {3, 3, 3}
Run Code Online (Sandbox Code Playgroud)
有没有一种可理解的方式这样做而不诉诸操纵底层IEnumerator<_>
类型?
澄清一下,这些是seq<seq<int>>
对象.每个序列(内部和外部)可以包含任意数量的项目.