Jeśli całkowita precyzja nie jest sprawą najwyższej wagi, można użyć float
numery
>>> 3**3**3
7625597484987
>>> 3.**3.**3.
7625597484987.0
Jednakże dla większych wartości te będą szybko osiągnąć swoje granice:
>>> 5.**5.**5.
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
OverflowError: (34, 'Numerical result out of range')
można uzyskać znacznie wyższe ze 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')
Domyślnie, nawet tych, którzy nie mogą reprezentować 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
Ale te granice nie są stałe.Korzystanie getcontext()
można uczynić je tak duża, jak chcesz:
>>> decimal.getcontext().Emax = 1000000000000
>>> d(10)**d(10)**d(10)
Decimal('1.000000000000000000000000000E+10000000000')
Należy jednak pamiętać, że te liczby nie są w 100% dokładne do ostatniej cyfry (komputer prawdopodobnie nawet nie ma wystarczającej ilości pamięci do sklepie każda cyfra) , więc nie zdziw się, jeśli tak się stanie:
>>> d(10)**d(10)**d(10) == d(10)**d(10)**d(10) + 1000000
True
Przechowywanie dodatniej liczby całkowitej X zajmuje przestrzeń O (log (X)). Więc jeśli X = N^(N^N), zajmie przestrzeń O ((N^N) log N). –