c – std :: count的复杂性

我在一些在线代码测验网站,其中存在复杂性限制,代码在时间和内存中不应超过O(N),其中N是向量A的大小.我的代码完全是(完整代码):
int foo(int X,const std::vector<int> &A) {
    auto N = A.size();
    auto total_hit = std::count(A.cbegin(),A.cend(),X);
    auto K = N - total_hit;
    if (K < 0 || K >= N){
        return -1;
    }
    return K;
}

我得到了一个超出时间复杂度的结果.有没有可能而不是错?

解决方法

根据 ref

Complexity: exactly last – first comparisons / applications of the predicate

他们错了!

并且cplusplus同意:

Complexity: Linear in the distance between first and last: Compares once each element.

当然,std::cbegin(),std::cend()std::vector::size()的复杂性是不变的.

如果我是你,我会联系该网站,将他们与这个问题联系起来.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...