我稍微看了mpz_import
,但是我不确定它的用法(很抱歉,我是gmp编程的新手)。我有一个std::vector<bool>
,过去这是我处理大数字时效率不高的一种方式。数字有时会大于32或64位,而我的数字也较小,我希望gmp能有效地处理此问题。现在,我想清理我的旧代码并改用gmp。
我使用C ++工作。所以我的问题是将vector<bool>
转换为mpz_t
的正确方法是什么。在我的应用程序中,我真的不关心整数的值,只要两个不同的向量(按其内容比较)表示不同的gmp整数即可。
答案 0 :(得分:0)
我认为mpz_import
不能正常工作。所以我最终使用了以下
mpz_t n; mpz_init(n);
for (size_t i = bignum.size(); i --> 0; )
if (bignum[i]) mpz_setbit(n,i);