首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Swift 'compactMap‘序列方法的时间复杂度

Swift 'compactMap‘序列方法的时间复杂度
EN

Stack Overflow用户
提问于 2020-09-14 21:59:42
回答 1查看 108关注 0票数 4

Swift文档指出,用于排序的compactMap()方法的时间复杂度为O(n + m),其中n是序列的长度,m是结果的长度。

但是,在查看标准库中的implementation时,我不明白为什么:

代码语言:javascript
复制
public func _compactMap<ElementOfResult>(
    _ transform: (Element) throws -> ElementOfResult?
  ) rethrows -> [ElementOfResult] {
    var result: [ElementOfResult] = []
    for element in self {
      if let newElement = try transform(element) {
        result.append(newElement)
      }
    }
    return result
  }

序列元素上只有一个循环,它应该是O(n)

EN

回答 1

Stack Overflow用户

发布于 2020-09-14 22:05:22

文档实际上并没有说明这是算法的time还是memory complexity

时间复杂度实际上是O(n),然而,存储器复杂度O(n+m),因为大小为n的原始代码被保存在存储器中,同时还创建了大小为< Array >d13Sequence >的新代码。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63885861

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档