Щоб перевірити, чи є число float цілим числом, використовуйте float.is_integer()
метод :
>>> (1.0).is_integer()
True
>>> (1.555).is_integer()
False
Метод був доданий до float
типу в Python 2.6.
Враховуйте, що в Python 2 1/3
є 0
(поділ підлоги для цілих операндів!), І що арифметика з плаваючою комою може бути неточною (a float
- наближення, використовуючи двійкові дроби, а не точне дійсне число). Але трохи регулюючи цикл, це дає:
>>> for n in range(12000, -1, -1):
... if (n ** (1.0/3)).is_integer():
... print n
...
27
8
1
0
що означає, що що-небудь більше 3-х кубів (включаючи 10648) було пропущено через вищезгадану неточність:
>>> (4**3) ** (1.0/3)
3.9999999999999996
>>> 10648 ** (1.0/3)
21.999999999999996
Натомість вам доведеться перевіряти номери, близькі до цілого числа, або не використовувати їх float()
для пошуку. Як округлення кореня куба 12000
:
>>> int(12000 ** (1.0/3))
22
>>> 22 ** 3
10648
Якщо ви використовуєте Python 3.5 або новішу версію , ви можете скористатися math.isclose()
функцією, щоб перевірити, чи значення плаваючої точки знаходиться в межах настроюваної межі:
>>> from math import isclose
>>> isclose((4**3) ** (1.0/3), 4)
True
>>> isclose(10648 ** (1.0/3), 22)
True
Для старих версій наївна реалізація цієї функції (пропуск перевірки помилок та ігнорування нескінченності та NaN), як зазначено в PEP485 :
def isclose(a, b, rel_tol=1e-9, abs_tol=0.0):
return abs(a - b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol)