你能帮我简化下面的流程吗? 范围是计算给定数组中每个元素重复的时间. var test = [1,2,3,4,5,6,7,8,5,9,3,3,9,9,9]var testCount = [Int:Int]()for curr in test { if let x = testCount[curr] { testCount[curr] = x + 1
范围是计算给定数组中每个元素重复的时间.
var test = [1,2,3,4,5,6,7,8,5,9,3,3,9,9,9] var testCount = [Int:Int]() for curr in test { if let x = testCount[curr] { testCount[curr] = x + 1 continue; } testCount[curr] = 1 } print(testCount)
我正在努力,以便有类似的东西:
test.map_duplicate() or map_duplicate(test)您可以将SequenceType扩展为具有函数freq,它完全符合您的需要.
extension SequenceType where Self.Generator.Element: Hashable { func freq() -> [Self.Generator.Element: Int] { return reduce([:]) { (var accu: [Self.Generator.Element: Int], element) in accu[element] = accu[element]?.successor() ?? 1 return accu } } }