8

如何在 c# 中实现这个 python 代码?

Python代码:

print(str(int(str("e60f553e42aa44aebf1d6723b0be7541"), 16)))

结果:

305802052421002911840647389720929531201

但是在 c# 中,我遇到了大数字的问题。

你能帮助我吗?

我在 python 和 c# 中得到了不同的结果。哪里可能出错?

4

3 回答 3

22

原始类型(例如Int32, Int64)的长度有限,对于这么大的数字来说是不够的。例如:

数据类型                                     最大正值
Int32 2,147,483,647
UInt32 4,294,967,295
Int64 9,223,372,036,854,775,808
UInt64 18,446,744,073,709,551,615
您的号码 305,802,052,421,002,911,840,647,389,720,929,531,201

在这种情况下,要表示该数字,您需要 128 位。在 .NET Framework 4.0 中,有一种用于任意大小整数的新数据类型System.Numerics.BigInteger。您不需要指定任何大小,因为它将由数字本身推断(这意味着您甚至可能OutOfMemoryException在执行时得到一个,例如,两个非常大的数字相乘)。

回到你的问题,首先解析你的十六进制数:

string bigNumberAsText = "e60f553e42aa44aebf1d6723b0be7541";
BigInteger bigNumber = BigInteger.Parse(bigNumberAsText,
    NumberStyles.AllowHexSpecifier);

然后只需将其打印到控制台:

Console.WriteLine(bigNumber.ToString());

您可能有兴趣计算需要多少位来表示任意数字,请使用此函数(如果我记得原始实现来自 C Numerical Recipes):

public static uint GetNeededBitsToRepresentInteger(BigInteger value)
{
   uint neededBits = 0;
   while (value != 0)
   {
      value >>= 1;
      ++neededBits;
   }

   return neededBits;
}

然后计算一个写成字符串的数字所需的大小:

public static uint GetNeededBitsToRepresentInteger(string value,
   NumberStyles numberStyle = NumberStyles.None)
{
   return GetNeededBitsToRepresentInteger(
      BigInteger.Parse(value, numberStyle));
}
于 2012-04-24T07:41:50.373 回答
3

如果您只想能够使用更大的数字,那么BigInteger它有很多数字。

于 2012-04-24T07:37:11.927 回答
0

要找到存储 a 所需的位数BigInteger N,可以使用:

BigInteger N = ...;
int nBits = Mathf.CeilToInt((float)BigInteger.Log(N, 2.0));
于 2019-09-15T14:53:15.920 回答