C#实现超长位整数运算

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#实现超长位整数运算相关的知识,希望对你有一定的参考价值。


.net中我们可用的最大长度数据类型为ulong(无符号64位)。

某些特殊情况下(如密码学),要求我们使用大于64位长度的超长整数进行加、减、乘、除,甚至求幂等诸多复杂运算。

针对于此种情况,.net4.0中专门提供了相应的数据类型BigInteger,来实现这种功能。

相关信息参考MSDN:

>> BigInteger 成员
​​​http://msdn.microsoft.com/zh-cn/library/system.numerics.biginteger_members.aspx​

>> BigInteger 结构

​http://msdn.microsoft.com/zh-cn/library/system.numerics.biginteger.aspx​

>> System.Numerics 命名空间

​http://msdn.microsoft.com/zh-cn/library/system.numerics.aspx​

 

不过,上文已经注明,此数据类型见于.net4.0。.net3.5中确实存在System.Numerics这一命名空间,但.net3.5中并不存在这一数据类型。而.net2.0中尚不存在此命名空间。

以下提供高手自建的BigInteger源码(.CS),可以在任意.net版本中加以使用,来实现上述要求的功能。

 

>> ​C# BigInteger Class​​ (​​CodeProject​​)

C#实现超长位整数运算_数据类型

以上是关于C#实现超长位整数运算的主要内容,如果未能解决你的问题,请参考以下文章

超长整数的基础运算 算法实现之乘除篇

超长数运算

大整数四则运算

超长整数运算(大数运算)

华为OJ平台——超长正整数相加

位运算实现整数运算