如何将一个非常大的数字提升到一个非常强大的力量?

TaG*_*deh 2 c# ulong pow

我有一个ulong值,我需要提高到高功率,但Math.Pow不能成功产生正确的输出.

我的c#代码:

 ulong a = 9123456789;
 ulong b = (ulong)Math.Pow(a, 9999);
 Console.WriteLine(b);
Run Code Online (Sandbox Code Playgroud)

屏幕输出为0.如何执行此计算并获得正确的结果?

Max*_*rdt 8

是的,可以使用专门的BigInteger类来计算该数字.尝试ushort使用宽度为16位的a 来做这个是没有希望的.

using System;
using System.Collections;
using System.Numerics;

public class Test 
{
    public static void Main(string[] args)
    {
        BigInteger a = 9123456789;
        BigInteger b = BigInteger.Pow(a, 9999);

        //Output this number if you're feeling lucky.
        Console.WriteLine(b);
    }
}
Run Code Online (Sandbox Code Playgroud)

输出

43056151396124937171542222696555900626431494491043369510338912076154406943108
..
8614367506747618876018379290109
Run Code Online (Sandbox Code Playgroud)

顺便说一句,你需要330,837位来存储结果.