首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >chars().count()时间复杂度

chars().count()时间复杂度
EN

Stack Overflow用户
提问于 2021-09-17 04:04:51
回答 1查看 421关注 0票数 4

我知道str.len()的时间复杂度是O(1),那么chars呢?str.chars().count() O(n)还是O(1)的时间复杂度?

此外,是否有类似于Python的锈蚀时间复杂性的站点?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-09-17 04:14:39

证物A

str.chars()返回一个Chars迭代器。看一下文档。少了点什么。

您会注意到,Chars没有实现ExactSizeIterator特性。如果得到的计数是O(1),我希望它能够实现这个特性。

展览B

向下滚动到它的Iterator::count实现,我们看到:

消耗迭代器,计算迭代次数并返回它。

计算迭代次数?这可不是个好消息。

证物C

让我们来看看源代码,这是真理的最终来源。我们能找到什么?

代码语言:javascript
复制
fn count(self) -> usize {
    // length in `char` is equal to the number of non-continuation bytes
    self.iter.filter(|&&byte| !utf8_is_cont_byte(byte)).count()
}

迭代?过滤器?数数?棺材里最后的钉子。

结论

女士们先生们,我是O(n)。我放下我的案子!

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

https://stackoverflow.com/questions/69217636

复制
相关文章

相似问题

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