Se la precisione intero non è della massima importanza, è possibile utilizzare float
numeri
>>> 3**3**3
7625597484987
>>> 3.**3.**3.
7625597484987.0
Tuttavia, per valori più grandi quelli raggiungerà presto i loro limiti:
>>> 5.**5.**5.
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
OverflowError: (34, 'Numerical result out of range')
si può ottenere molto più alto con 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')
Per impostazione predefinita, anche quelli che non può rappresentare 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
Ma questi limiti non sono fissi.Utilizzando getcontext()
si può renderli grande come si desidera:
>>> decimal.getcontext().Emax = 1000000000000
>>> d(10)**d(10)**d(10)
Decimal('1.000000000000000000000000000E+10000000000')
Ma ricordate che quei numeri non sono al 100% precisi per l'ultima cifra (il computer probabilmente non ha nemmeno di memoria sufficiente per negozio ogni cifra) , quindi non essere sorpreso se questo accade:
>>> d(10)**d(10)**d(10) == d(10)**d(10)**d(10) + 1000000
True
Memorizzare il numero intero positivo X occupa spazio O (log (X)). Quindi se X = N^(N^N), occorrerà spazio O ((N^N) log N). –