我可能有一个如下所示的数组:
[1,4,2,6,24,15,2,60,6]
或者,实际上,任何类似类型的数据序列。我想要做的是确保每个相同的元素只有一个。例如,上面的数组将变为:
[1,60]
请注意,删除了重复的2,6和15,以确保每个相同的元素只有一个。 Swift是否提供了一种轻松完成此操作的方法,或者我是否必须自己完成此操作?
您可以自己滚动,例如像这样(使用Set更新为Swift 1.2):
func uniq<S : SequenceType,T : Hashable where S.Generator.Element == T>(source: S) -> [T] { var buffer = [T]() var added = Set<T>() for elem in source { if !added.contains(elem) { buffer.append(elem) added.insert(elem) } } return buffer } let vals = [1,6,15,6] let uniqueVals = uniq(vals) // [1,60]
Swift 3版本:
func uniq<S : Sequence,T : Hashable>(source: S) -> [T] where S.Iterator.Element == T { var buffer = [T]() var added = Set<T>() for elem in source { if !added.contains(elem) { buffer.append(elem) added.insert(elem) } } return buffer }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。