std :: copia n elementos o hasta el final

Me gustaría copiar hasta N elementos.

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;
}

¿Hay alguna manera de hacer esto con las funciones estándar? Yo también podría:

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);
}

sin embargo, además de ser engorroso, supera el rango dos veces (distancia, copia). Si estoy usando un iterador de transformación, o un iterador de filtro, esas son llamadas innecesarias O (N) a mi función de filtro / transformació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 << " ,";
}

salidas 1,2,3,4,5,6,7,8,9,

sin embargo, esto continuará hasta el final y no contará los tiempos. aún así, más llamadas innecesarias a mi función de filtro / transformación ...

Respuestas a la pregunta(4)

Su respuesta a la pregunta