Вы также можете использовать Math.pow:
>>> import math
>>> math.pow(3,2)
9.0
Хотя на самом деле это выглядит, может быть, это не самая лучшая идея, так как Math.pow больше для расширения C совместимость, и не обрабатывает все случаи, которые ** делает:
>>> 2**3000
1230231922161117176931558813276752514640713895736833715766118029160058800614672948775360067838593459582429649254051804908512884180898236823585082482065348331234959350355845017413023320111360666922624728239756880416434478315693675013413090757208690376793296658810662941824493488451726505303712916005346747908623702673480919353936813105736620402352744776903840477883651100322409301983488363802930540482487909763484098253940728685132044408863734754271212592471778643949486688511721051561970432780747454823776808464180697103083861812184348565522740195796682622205511845512080552010310050255801589349645928001133745474220715013683413907542779063759833876101354235184245096670042160720629411581502371248008430447184842098610320580417992206662247328722122088513643683907670360209162653670641130936997002170500675501374723998766005827579300723253474890612250135171889174899079911291512399773872178519018229989376L
против
>>> import math
>>> math.pow(2, 3000)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
OverflowError: math range error
см http://mail.python.org/pipermail/python-list/2003-November/236169.html для немного более подробно
EDIT: В ответ на ваш вопрос, почему он возвращается 0.0, это потому, что вы поднимаете 0 к власти - вы используете/для разделения, который по умолчанию является целым делением и будет усекаться. используйте from __future__ import division
, чтобы получить дивиденды с плавающей запятой.
Вместо того, чтобы спрашивать, почему бы вам не попробовать ввести части своего выражения в python и посмотреть, какие из них не ведут себя так, как вы ожидаете? – 2010-04-17 13:32:35