+template < typename N, typename E >
+number< N, E >& number< N, E >::operator-= (const number< N, E >& n)
+{
+ // minuendo - substraendo
+ number< N, E > minuend;
+ number< N, E > subtrahend;
+
+ // voy a hacer siempre el mayor menos el menor
+ if (*this < n)
+ {
+ minuend = n;
+ subtrahend = *this;
+ //minuendo < sustraendo => resultado negativo
+ minuend.sign = negative;
+ }
+ else
+ {
+ minuend = *this;
+ subtrahend = n;
+ //minuendo > sustraendo => resultado positivo
+ minuend.sign = positive;
+ }
+
+ size_type ini = 0;
+ size_type fin = std::min(minuend.chunk.size(), subtrahend.chunk.size());
+ size_type i; //problema de VC++, da error de redefinición
+
+ //estoy seguro de que minuend > subtrahend, con lo cual itero hasta el size del
+ //menor de los dos. Si el otro es más grande, puede ser que esté lleno de 0's pero
+ //no puede ser realmente mayor como cifra
+ for (i = ini; i < fin; ++i)
+ {
+ // si no alcanza para restar pido prestado
+ if ((minuend.chunk[i] < subtrahend.chunk[i]))
+ {
+ // no puedo pedir si soy el más significativo ...
+ assert (i != fin);
+
+ // le pido uno al que me sigue
+ minuend.borrow(i+1);
+ }
+
+ // es como hacer 24-5: el 4 pide prestado al 2 (borrow(i+1)) y después
+ // se hace 4 + (9-5) + 1
+
+ minuend.chunk[i] += (~((N)0) - subtrahend.chunk[i]) + 1;
+ }
+
+ //retorno el minuendo ya restado
+ *this = minuend;
+ return *this;
+}
+
+template < typename N, typename E >
+number< N, E > operator- (const number< N, E >& n1, const number< N, E >& n2)
+{
+ number< N, E > tmp = n1;
+ tmp -= n2;
+ return tmp;
+}
+
+
+template < typename N, typename E >
+bool number< N, E >::operator< (const number< N, E >& n)
+{
+ number< N, E > n1 = *this;
+ number< N, E > n2 = n;
+
+ // igualo los largos
+ normalize_length(n1, n2);
+
+ // obtengo el largo
+ size_type length = n1.chunk.size();
+ size_type i = length - 1;
+
+ // me voy fijando desde "la cifra" más significativa si alguno es menor que el otro
+ // sigo iterando si son iguales hasta recorrer todo el número hasta la parte menos significativa
+ while (i > 0)
+ {
+ if (n1[i]<n2[i])
+ return true;
+ if (n1[i]>n2[i])
+ return false;
+
+ i--;
+ }
+
+ // si llegué hasta acá es porque son iguales, por lo tanto no es menor estricto
+ return false;
+
+}
+