Store and work with Big numbers in C

北城余情 提交于 2019-11-26 02:15:03

问题


I need help working with very big numbers. According to Windows calc, the exponent

174^55 = 1.6990597648061509725749329578093e+123 

How would I store this using C (c99 standard)?

int main(){
  long long int x = 174^55; //result is 153
  printf(\"%lld\\n\", x);
}

回答1:


Normal types in C can usually only store up to 64 bits, so you'll have to store big numbers in an array, for example, and write mathematical operations yourself. But you shouldn't reinvent the wheel here - you could try the GNU Multiple Precision Arithmetic Library for this purpose.

And as the comments already pointed out, the ^ operation is binary XOR. For exponentiation, you will have to use mathematical functions like pow.




回答2:


If approximation is OK, you can use floating-point (float or double) numbers. And you need pow, not ^, as the commenters said.

However, for cryptography, approximation doesn't work. You need support for arithmetic with very large integers. GMP provides general multiple-precision arithmetic support. Many cryptographic packages will also have such algorithms in their code, either through a third-party library or built-in; PuTTY has a bignum library for large integers, and OpenSSL probably has something similar.

Basic C data types are not enough.




回答3:


You could store it in an array of integers. A 64-bit integer is just 2 32-bit integers. A 1024 bit integer could also be seen as 32 32-bit integers.



来源:https://stackoverflow.com/questions/2640625/store-and-work-with-big-numbers-in-c

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!