Si consideras numeros que pueden contenerse en un entero (o entero largo), en realidad los arreglos no son necesarios para resolver ese particular problema.
Si solo deseas escribir el nro invertido, sin almacenarlo, hacer un ciclo calculando el modulo 10 te da el ultimo digito, dividirlo por 10 te da el trozo izquierdo. Si deseas construir el nro invertido, bastaria con agregar la aritmetica (multiplicar x 10 y sumar el nuevo nro).
Algo parecido a (siendo "n" el nro, positivo)
Código C++:
Ver originalinv = 0;
while( n >0 )
{
d = n % 10;
printf( "%d", d
); // si se desea imprimir el numero digito a digito
inv = 10 * inv + d; // no es necesario si no se quiere almacenar
n = n / 10;
}
printf( "\nNro invertido: %d\n", inv
);
Para números de largo mayor al que puede contenerse en un entero, si se hace necesario usar arreglos y olvidarse finalmente que se trata de numeros. De hecho, el codigo anterior podría fallar si el numero invertido (almacenado en la variable inv) no cabe en un entero.