您可以使用该
reduce方法。
还原如何工作?let result = numbers.reduce([[Int]]()) { (var result, num) -> [[Int]] in if var lastSequence = result.last where lastSequence.first == num { result[result.count-1].append(num) } else { result.append([num]) } return result}
reduce确实将闭包中的逻辑应用于空的2D整数数组(
[[Int]])和的第一个elm
numbers。
然后将其再次应用于上一次迭代的结果和第二个整数数组…等等。
关闭会发生什么?在
if做检查添加到结果的最后一个数组中的号码是否等于当前检查的整数。如果是这样,则将整数添加到该数组。
否则,将仅包含新整数的新数组添加到结果中。
测试[[7, 7], [3], [2, 2, 2], [1], [7], [5, 5]]
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)