Ant*_*ton 2 arrays closures swift
我们有一个数组,例如:
let numbers = [-1.0,1.0,3.0,4.0,-1.0,-2.0,2.0]
Run Code Online (Sandbox Code Playgroud)
我们知道如何获得最大连续正数:
let pos = numbers.map({ () -> (Double) -> Int in var c = 0; return { c = $0 > 0 ? c + 1 : 0; return c } }())
// [0, 1, 2, 3, 0, 0, 1]
let maxConsecutivePos = pos.max()!
//3
Run Code Online (Sandbox Code Playgroud)
在我们的例子中,如何使用闭包和pos数组以相同的方式找到平均连续正数?对于这个例子,我们将sum(3 + 1)除以2 - > 2是预期输出.
一种可能的解决方案:将数组拆分为连续正数的切片,然后计算平均切片长度:
let numbers = [-1.0, 1.0, 3.0, 4.0, -1.0, -2.0, 2.0]
let slices = numbers.split(whereSeparator: { $0 <= 0 })
// --> [ArraySlice([1.0, 3.0, 4.0]), ArraySlice([2.0])]
let avg = Double(slices.reduce(0, { $0 + $1.count })) / Double(slices.count)
print(avg) // 2.0
Run Code Online (Sandbox Code Playgroud)