如何在C中添加2个任意大小的整数?

我想在C中添加2个任意大小的整数.我该怎么做呢?

解决方法:

这是一个示例,说明如何将OpenSSL bignum实现用于任意精度算术.我的例子是264 265.我正在使用Linux.

#include <cstdio>
#include <openssl/crypto.h>
#include <openssl/bn.h>

int main(int argc, char *argv[])
{
        static const char num1[] = "18446744073709551616";
        static const char num2[] = "36893488147419103232";

        BIGNUM *bn1 = NULL;
        BIGNUM *bn2 = NULL;

        BN_CTX *ctx = BN_CTX_new();

        BN_dec2bn(&bn1, num1); // convert the string to BIGNUM
        BN_dec2bn(&bn2, num2);

        BN_add(bn1, bn1, bn2); // bn1 = bn1 + bn2

        char *result_str = BN_bn2dec(bn1);  // convert the BIGNUM back to string
        printf("%s + %s = %s\n", num1, num2, result_str);
        OPENSSL_free(result_str);

        BN_free(bn1);
        BN_free(bn2);
        BN_CTX_free(ctx);

        return 0;
}

它产生这个输出:

18446744073709551616 + 36893488147419103232 = 55340232221128654848

您需要在开发库中安装OpenSSL.如果您有Linux,请从软件包管理器安装开发库,并使用libcrypto.so进行链接.

g++ bignum.cpp -o bignum -lcrypto

或者下载OpenSSL源代码并构建静态库libcrypto.a并静态链接它.

g++ bignum.cpp -o bignum -I./openssl-1.0.0/include ./openssl-1.0.0/libcrypto.a

在Windows上,您需要从OpenSSL的Windows port安装.

上一篇:【历史遗留】还有记录的:HDOJ-刷题.md


下一篇:JavaScript处理大数字(BigNum)的标准解决方案是什么?