__int64不够用,__int128如何自己实现?

dibotiger 2011-04-20 09:19:31
写了个密码排列组合有关的程序.

要计算所有的可能,结果__int64都不够用了.


有没有比较全面的__int128实现方案:

1.支持基本的运算.并支持和其它类型(如DWORD64 DWORD)等数据进行运算.

2.支持该类型数据的格式化输出.如如何实现printf("%I128d",i)来输出这个数字.


...全文
1421 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
dibotiger 2011-04-25
  • 打赏
  • 举报
回复
多说两句.给后来的有用的人提个醒:

Miracl库和CXWord类都是不错的方案.

但前者不支持运算符, 比较遗憾.
用户 昵称 2011-04-21
  • 打赏
  • 举报
回复
算法里经常用大数,目前rsa算法vc版基本上都支持4096位计算了,里面大数+-*/都支持。
smwhotjay 2011-04-21
  • 打赏
  • 举报
回复
自己union定义个结构来实现.. 但超过32位的变量貌似都非原子了. 所以多线程要lock
Eleven 2011-04-21
  • 打赏
  • 举报
回复
向立天 2011-04-21
  • 打赏
  • 举报
回复
帝国队长 2011-04-21
  • 打赏
  • 举报
回复
实在不行就用高低字节,以前不也这样解决的吗?
jyh_baoding 2011-04-21
  • 打赏
  • 举报
回复
建议采用字符数组保存
  • 打赏
  • 举报
回复 1

struct _int128
{
int i1;
int i2;
int i3;
int i4;
}
healer_kx 2011-04-20
  • 打赏
  • 举报
回复
我关系里面的实现,,,,
微笑的鱼 2011-04-20
  • 打赏
  • 举报
回复
struct __int128
{
byte data[128/8];
}

再重载几个基本的运算符,应该可以实现的。
TandyT 2011-04-20
  • 打赏
  • 举报
回复
大数运算的实现,,,,用字符数组扩展吧。。。。。
masterz 2011-04-20
  • 打赏
  • 举报
回复
http://sourceforge.net/projects/cpp-bigint/
C++ class BigInt that enables the user to work with arbitrary precision integers.

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧