BigInt<1024> n(1); // вычислить факториал числа 32
for (int 1=1; i <= 32; ++i) {
n *= i;
}
outputBigInt(n);
}
Программа
примера 11.39 выдает следующий результат.
263130836933693530167218012160000000
Обсуждение
Большие целые числа часто встречаются во многих приложениях. Например, в криптографии нередки числа, которые представляются 1000 и более битами. Однако современный стандарт C++ позволяет работать как максимум с типом
long int
.
Число бит типа
long int
зависит от реализации, но оно не может быть меньше 32. И едва ли это число будет больше 1000. Следует помнить, что один из этих битов используется в качестве знака.
Ожидается, что новая версия стандарта (C++0x) последует за стандартом C99 и предусмотрит тип
long long
, размер которого будет, по крайней мере, не меньше размера
long int
, а возможно, и больше. Несмотря на это, всегда будут случаи, когда требуется наличие целочисленного типа, размер которого превышает размер самого большого встроенного типа.
Представленная здесь реализация основана на двоичном представлении чисел при помощи класса
bitset
, причем это делается за счет некоторого снижения производительности. Однако я потерял в производительности значительно меньше, чем выиграл в простоте. Более эффективная реализация чисел произвольной точности настолько обширна, что могла бы легко заполнить всю книгу.
Смотри также
Рецепт 11.19.
11.21. Реализация чисел с фиксированной точкой
Проблема
Требуется обеспечить выполнение вычислений с вещественными числами, используя тип с фиксированной, а не с плавающей точкой.
Решение
В примере 11.40 представлена реализация вещественного числа с фиксированной точкой, когда количество двоичных позиций справа от точки задается параметром шаблона. Например, тип
basic_fixed_real<10>
имеет 10 двоичных цифр справа от двоичной точки, что позволяет представлять числа с точностью до 1/1024.
Пример 11.40. Представление вещественных чисел, используя формат с фиксированной точкой