如何从列表中生成字典?
采取以下列表:
let numbers = [1;2;2;3;3;3;4;5;5;]
如何生成一个字典,其中键是元素,值是元素在列表中出现的次数?
我的悲惨尝试:
let numbers = [1;2;2;3;3;3;4;5;5;]
numbers |> Seq.fold (fun accumulator element -> Map.add (element, element list???) 0)
答案 0 :(得分:3)
let numbers = [1;2;2;3;3;3;4;5;5]
let map = numbers |> Seq.groupBy id |> Map.ofSeq
map |> Map.iter (printfn "%A - %A")
打印强>
1 - seq [1]
2 - seq [2; 2]
3 - seq [3; 3; 3]
4 - seq [4]
5 - seq [5; 5]
链接:强>
https://dotnetfiddle.net/xyNyzn
修改强>
如果你想获得:数字 - 频率(现在使用Seq.fold:))
let addElement (acc:Map<int,int>) element =
if acc.ContainsKey element then acc.Add(element, acc.[element] + 1)
else acc.Add(element, 1)
(Map.empty, numbers)
||> Seq.fold (addElement)
|> Map.iter (printfn "%A - %A")
打印强>
1 - 1
2 - 2
3 - 3
4 - 1
5 - 2
链接:强>
答案 1 :(得分:0)
您的示例代码使用Map
,但是,假设您所说的Dictionary
,可以编写这样的函数:
Seq.countBy id >> dict