Если целочисленная точность не первостепенное значения, вы можете использовать float
номер
>>> 3**3**3
7625597484987
>>> 3.**3.**3.
7625597484987.0
Однако для больших значений те быстро достигают свои пределы:
>>> 5.**5.**5.
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
OverflowError: (34, 'Numerical result out of range')
Вы можете получить гораздо больше с decimal
:
>>> import decimal
>>> d = decimal.Decimal
>>> d(5)**d(5)**d(5)
Decimal('1.911012597945477520356404560E+2184')
>>> d(10)**d(10)**d(8)
Decimal('1.000000000000000000000000000E+100000000')
По умолчанию, даже те, которые не могут представлять 10**10**10
:
>>> d(10)**d(10)**d(10)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.7/decimal.py", line 2386, in __pow__
ans = ans._fix(context)
File "/usr/lib/python2.7/decimal.py", line 1676, in _fix
ans = context._raise_error(Overflow, 'above Emax', self._sign)
File "/usr/lib/python2.7/decimal.py", line 3872, in _raise_error
raise error(explanation)
decimal.Overflow: above Emax
Но эти ограничения не являются фиксированными.Использование getcontext()
вы можете сделать их как большой, как вы хотите:
>>> decimal.getcontext().Emax = 1000000000000
>>> d(10)**d(10)**d(10)
Decimal('1.000000000000000000000000000E+10000000000')
Но помните, что эти цифры не являются 100% точным до последней цифры (ваш компьютер, вероятно, даже не хватает памяти для магазина каждая цифра) , поэтому не удивляйтесь, если это произойдет:
>>> d(10)**d(10)**d(10) == d(10)**d(10)**d(10) + 1000000
True
Хранение положительного целого числа X занимает пространство O (log (X)). Итак, если X = N^(N^N), то возьмем O ((N^N) log N) пространство. –