OpenSSL测试-大数
作者:互联网
-
基于OpenSSL的大数库计算2的N次方,N为你学号的后四位(5‘)
-
基于OpenSSL的大数库计算你以及前面5位同学和后面5位同学的8位学号的乘积,N为你学号的后四位(5‘)
#pragma comment(lib,"libssl.lib")
#pragma comment(lib,"libcrypto.lib")
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <string.h>
#include <openssl/bn.h>
int main(int argc, char* argv[])
{
//
BN_CTX* pBNctx = BN_CTX_new();
BIGNUM* n = BN_new();
BN_set_word(n, 1301);
BIGNUM* two = BN_new();
BN_set_word(two, 2);
BIGNUM* r = BN_new();
BN_exp(r, two, n, pBNctx);
char* pR = BN_bn2dec(r);
//printf("2^1210 =%s \n", pR);
BIGNUM* rr = BN_new();
BIGNUM* n1 = BN_new();
BIGNUM* n2 = BN_new();
int i;
BN_set_word(n1, 20191301);
BN_set_word(n2, 20191302);
BN_mul(rr, n1, n2,pBNctx);
for (i = 20191301; i <= 20191308; i++)
{
BN_set_word(n1, i);
// char* pR = BN_bn2dec(n1);
// printf(" =%s \n", pR);
BN_mul(rr, rr, n1,pBNctx);
}
pR = BN_bn2dec(rr);
printf("b=%s \n", pR);
return 0;
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <openssl/bn.h>
int main()
{
BIGNUM * bn_rlt;
BIGNUM * bn_2;
BN_CTX * ctx;
char* show;
ctx=BN_CTX_new();
bn_rlt=BN_new();
bn_2=BN_new();
BN_dec2bn(&bn_rlt,"1");
BN_dec2bn(&bn_2,"2");
for(int i=0;i<1301;i++){
BN_mul(bn_rlt,bn_rlt,bn_2,ctx);
}
show=BN_bn2dec(bn_rlt);
printf("%s\n",show);
BN_free(bn_rlt);
BN_free(bn_2);
BN_CTX_free(ctx);
return 0;
}
标签:BIGNUM,大数,int,BN,OpenSSL,测试,new,include,bn 来源: https://www.cnblogs.com/20191301lhq/p/16262335.html