如何存储极大数量?

时间:2013-08-05 14:06:23

标签: c++ data-structures int large-data

例如,我有一个因子程序,需要保存可能超过50位数的巨大整数。 C ++中的绝对最大原始数据类型是unsigned long long int,其最大值18446744073709551615只有20位数。这是C ++限制的链接:http://www.cplusplus.com/reference/climits/

如何存储大于某种变量的数字?

4 个答案:

答案 0 :(得分:13)

如果你已经有一个提升依赖(这些天很多人都这样做),你可以使用提升multi-precision library。事实上,它已经有一个factorial program的例子,可以支持高达128位的输出,但进一步扩展它是非常微不足道的。

答案 1 :(得分:7)

您必须使用bigint或bignum实现。有一些库像这样:http://gmplib.org/

更多信息和图书清单:http://en.wikipedia.org/wiki/Bignum

答案 2 :(得分:3)

您可以使用数组。首先你应该复制那个巨大的数字数组,然后在19位之后使用逗号:

unsigned long long int num[]= {
        7316717653133062491,9225119674426574742,3553491949349698352,0,312774506326239578,3180169848018694788,
        5184385861560789112,9494954595017379583,3195285320880551112,5406987471585238630,5071569329096329522,
        7443043557668966489,5044524452316173185,6403098711121722383,1136222989342338030,8135336276614282806,
        4444866452387493035,8907296290491560440,7723907138105158593,0,7960866701724271218,8399879790879227492,
        1901699720888093776,6572733300105336788,1220235421809751254,5405947522435258490,7711670556013604839,
        5864467063244157221,5539753697817977846,1740649551492908625,6932197846862248283,9722413756570560574,
        9026140797296865241,4535100474821663704,8440319989000889524,3450658541227588666,8811642717147992444,
        2928230863465674813,9191231628245861786,6458359124566529476,5456828489128831426,0,7690042242190226710,
        5562632111110937054,4217506941658960408,0,7198403850962455444,3629812309878799272,4428490918884580156,
        1660979191338754992,0,0,5240636899125607176,0,6058861164671094050,7754100225698315520,0,0,
        5593572972571636269,5618826704282524836,0,0,8232575304207529634,50};

答案 3 :(得分:0)

有很多方法可以存储大量数字,如下所示:

  1. 字符串
  2. 文件
  3. 链接列表
  4. 向量/动态数组

注意:请不要使用数组来避免内存问题。

相关问题