]> git.llucax.com Git - z.facultad/75.29/dale.git/blobdiff - src/number.h
Acomodar el split().
[z.facultad/75.29/dale.git] / src / number.h
index 7df04e172b9bb81511748c9a9097a8f903b456da..28e853e3f244edc2372e7c4222caa26cd066d263 100644 (file)
@@ -7,6 +7,7 @@
 #include <deque>
 #include <utility>
 #include <algorithm>
+#include <iomanip>
 #include <stdint.h>
 
 /* sizeof(E) tiene que ser 2*sizeof(N); y son los tipos nativos con los cuales
@@ -217,7 +218,8 @@ std::ostream& operator<< (std::ostream& os, const number< N, E >& n)
        // FIXME sacar una salida bonita en ASCII =)
        for (typename number< N, E >::const_iterator i = n.chunk.begin();
                        i != n.chunk.end(); ++i)
-               os << std::hex << *i << " ";
+               os << std::setfill('0') << std::setw(sizeof(N) * 2) << std::hex
+                       << *i << " ";
        return os;
 }
 
@@ -269,14 +271,16 @@ std::pair< number< N, E >, number< N, E > > number< N, E >::split() const
        std::pair< num_type, num_type > par;
 
        // la primera mitad va al pedazo inferior
-       for (i = 0; i < halves_size; i++)
+       par.first.chunk[0] = chunk[0];
+       for (i = 1; i < halves_size; i++)
        {
                par.first.chunk.push_back(chunk[i]);
        }
 
        // la segunda mitad (si full_size es impar es 1 más que la primera
        // mitad) va al pedazo superior
-       for ( ; i < full_size; i++)
+       par.second.chunk[0] = chunk[i];
+       for (i++ ; i < full_size; i++)
        {
                par.second.chunk.push_back(chunk[i]);
        }