que - Agregar una matriz C a un vector en orden inverso en C++ 98/03 sin un bucle for
que es una matriz en programacion (2)
Es bastante sencillo añadir una matriz C a un vector (en C ++ 98/03) así:
std::vector<int> vec;
const int array[5] = { 1 , 2 , 3 , 4 , 5};
vec.insert( vec.end() , array , array + 5 );
¿Hay alguna manera de agregar la matriz a un vector en orden inverso en C ++ 98/03 sin escribir un for-loop? (Te estoy viendo Sean Parent).
Hay que ir Use std::reverse_copy
con std::back_inserter
para agregar elementos al vector:
std::vector<int> vec;
int array[5] = { 1 , 2 , 3 , 4 , 5};
std::reverse_copy(array , array + 5, std::back_inserter(vec));
Si le preocupa el rendimiento, no olvide reserve()
antes de copiar.
vec.insert(std::end(vec),
std::rbegin(array),
std::rend(array));
Tenga en cuenta que esto utiliza C ++ 14, pero los iteradores inversos han existido durante mucho más tiempo, solo tendría que crearlos manualmente si se atasca con un estándar anterior:
int const a1[] = {1, 2, 3, 4, 5};
int a2[5];
std::copy(std::reverse_iterator<int const*>(std::end(a1)),
std::reverse_iterator<int const*>(std::begin(a1)),
std::begin(a2)); // copy in reverse
std::copy(std::begin(a2),
std::end(a2),
std::ostream_iterator<int>(std::cout, " ")); // prints "5 4 3 2 1 "