我的例子有效,但缺乏多种方式.它适用于不适用于所有序列的数组,当第一个序列用完元素时,它会停止生成元组.我希望nils能够在元组中找到不能再提供元素的短序列.它只适用于两个数组,我希望它适用于任意数量的序列,
部分解决方案会有所帮助.我是一个功能性编程新手,所以这个功能的正确名称也将受到赞赏.也许它已经在switfz库中我只知道它叫什么.我选择了“join”,因为它大致类似于sql“join”,它也构建了元组(a.k.a. rows)
func join<T> (s1: Array<T>,s2: Array<T>) -> Array<(T,T)> {var g1 = s1.generate();var g2 = s2.generate();var result:Array<(T,T)> = []while let e1 = g1.next() { if let e2 = g2.next() { result.append((e1,e2)) }}return result}class Hamming { class func compute(input: String,against: String) -> Int { return join(Array(input),Array(against)).reduce(0){ return (.0 != .1) ?已有一个名为Zip2的函数:var first = [0,1,2,3]var second = ["zero","one","two","three"]Array(Zip2(first,second))// (0,"zero"),(1,"one"),(2,"two"),(3,"three")+ 1 :struct Zip2WithNilpadding<T: SequenceType,U: SequenceType>: SequenceType { typealias Generator = GeneratorOf<(T.Generator.Element?,U.Generator.Element?)> let first: T let second: U init(_ first: T,_ second: U) { self.first = first self.second = second } func generate() -> Generator { var generator1: T.Generator? = first.generate() var generator2: U.Generator? = second.generate() return GeneratorOf<(T.Generator.Element?,U.Generator.Element?)>() { let element1 = generator1?.next() let element2 = generator2?.next() if element1 == nil && element2 == nil { return nil } else if element1 == nil{ generator1 = nil } else if element2 == nil { generator2 = nil } return (element1,element2) } }}var first = [0,2]var second = ["zero","three","four"]Array(Zip2WithNilpadding(first,second))} }}Hamming.compute("abcde","abcdf") // 1
但是这个函数不用nil填充,它也使用两个传递顺序中最短的函数.请注意,它不要求两个序列之间的类型匹配,并且它需要任何序列,而不仅仅是数组.
这是我自己的Zip2WithNilpadding自定义实现:
如果您对具体实施有疑问,请告诉我,我会尽力澄清.此实现还应该帮助您创建一个采用序列数组的Zip.不幸的是,在这种情况下,它们都必须是相同类型的序列,因为你不能拥有可变数量的泛型.
总结以上是内存溢出为你收集整理的数组 – 在Swift中我想将两个序列“连接”到一系列元组中全部内容,希望文章能够帮你解决数组 – 在Swift中我想将两个序列“连接”到一系列元组中所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)