鱼C论坛

 找回密码
 立即注册
查看: 1646|回复: 10

[已解决]C++如何处理超大数据的计算比如2000的阶乘

[复制链接]
发表于 2019-11-23 21:12:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
经过我不懈的探查发现我的电脑64位Win10用64位vscode
最大 能算1754的阶乘.还不保证准确度,错到姥姥家去了
1755就是inf无穷大
最佳答案
2019-11-23 22:24:48
#include <iostream>
#include <boost/multiprecision/cpp_int.hpp>

int main(void)
{
        boost::multiprecision::cpp_int number("12345678900987654321");
        std::cout << boost::multiprecision::pow(number, 1234) << std::endl;
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-11-23 21:39:30 From FishC Mobile | 显示全部楼层
本帖最后由 jackz007 于 2019-11-23 22:21 编辑

       那就得上密码学常用的大数运算库了吧?

       我测试过,64 位整型能够计算的最大阶乘是 21,如果超过,就会溢出。

       21 的阶乘结果是 : 0x21C3677C82B40000

       22 的阶乘结果是 : 0x2C5077D36B8C40000 显然,这个结果已经超过 64 位了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-23 22:24:48 | 显示全部楼层    本楼为最佳答案   
#include <iostream>
#include <boost/multiprecision/cpp_int.hpp>

int main(void)
{
        boost::multiprecision::cpp_int number("12345678900987654321");
        std::cout << boost::multiprecision::pow(number, 1234) << std::endl;
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-23 22:30:03 | 显示全部楼层
jackz007 发表于 2019-11-23 21:39
那就得上密码学常用的大数运算库了吧?

       我测试过,64 位整型能够计算的最大阶乘是 21,如 ...

那就上大数运算库吧,boost走起
^_^
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-24 00:30:02 | 显示全部楼层
大数运算   你自己写程序 用数组保存数字  
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-11-24 00:33:32 | 显示全部楼层

这个库要单独下?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-11-24 00:35:57 | 显示全部楼层
我叫MD 发表于 2019-11-24 00:30
大数运算   你自己写程序 用数组保存数字

加减乘幂,阶乘我会写
我会写,但是开方,多次开方就不会写了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-24 01:48:48 | 显示全部楼层

你竟然不知道boost库?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-24 01:49:51 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-11-24 01:57:21 | 显示全部楼层
人造人 发表于 2019-11-24 01:48
你竟然不知道boost库?

书上提到过.
但是不确定GCC有没有自带
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-24 02:17:28 | 显示全部楼层
bin554385863 发表于 2019-11-24 01:57
书上提到过.
但是不确定GCC有没有自带

应该没有自带,需要自己安装
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-4 23:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表