我想复制最多N个元素。

template< class InputIt, class Size, class OutputIt>
OutputIt myCopy_n(InputIt first, InputIt last, Size count, OutputIt result)
{
    Size c = count;
    while (first != last && c > 0) {
        *result++ = *first++;
        --c;
    }
    return result;
}

有没有办法用标准功能做到这一点?我还可以:
template< class InputIt, class Size, class OutputIt>
OutputIt myCopy_n(InputIt first, InputIt last, Size count, OutputIt result)
{
    if(std::distance(first, last) > count)
        return std::copy_n(first,count,result);
    return std::copy(first,last,result);
}

但是,除了麻烦之外,它还超出了范围两次(距离,副本)。如果我使用转换迭代器或过滤器迭代器,则这些是对我的过滤器/转换函数的O(N)不必要的调用。
template <class InputIt, class OutputIt>
OutputIt copy_n_max(InputIt begin, InputIt end, OutputIt last, size_t count)
{
    return std::copy_if(begin, end, last,
                        [&count](typename std::iterator_traits<InputIt>::reference)
                        { return count--> 0; });
}

int main()
{
    std::vector<int> v({1,2,3,4,5,6,7,8,9}), out;
    copy_n_max(v.begin(), v.end(), std::back_inserter(out), 40);
    for(int i : out) std::cout <<i << " ,";
}

输出1,2,3,4,5,6,7,8,9,

但是,这将一直持续到结束,而不是次数。所以仍然有更多不必要的调用我的过滤器/转换功能...

最佳答案

如果您有权访问整个数据结构及其大小,则可以使用以下方法:

std::vector<int> v1, v2;
std::copy_n(v2.begin(), std::min(NUM, v2.size()), std::back_inserter(v1));

如果您只能访问迭代器,我将不知道如何仅使用std函数而不计算距离。对于随机访问迭代器而言,这是便宜的,但是对于其他类型的迭代器来说,重复项是可行的。
std::vector<int>::iterator i_begin, i_end, o_begin;
std::copy_n(i_begin, std::min(NUM, std::distance(i_begin, i_end)), o_begin);

10-08 11:19