我试着找出最大的立方根它是一个整数,小于12000。

processing = True
n = 12000
while processing:
    n -= 1
    if n ** (1/3) == #checks to see if this has decimals or not

我不知道如何检查,如果它是一个整数或不是!我可以将其转换为字符串,然后使用索引来检查结束值,看看它们是否为零,这似乎相当麻烦。有没有更简单的方法?


当前回答

只是一个附加信息,is_integer在内部执行:

import math
isInteger = (math.floor(x) == x)

并不完全是在python中实现的,但cpython实现如上所述。

其他回答

上述答案适用于许多情况,但也有遗漏。考虑以下几点:

fl = sum([0.1]*10)  # this is 0.9999999999999999, but we want to say it IS an int

以此为基准,其他一些建议并没有得到我们想要的行为:

fl.is_integer() # False

fl % 1 == 0     # False

而不是尝试:

def isclose(a, b, rel_tol=1e-09, abs_tol=0.0):
    return abs(a-b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol)

def is_integer(fl):
    return isclose(fl, round(fl))

现在我们得到:

is_integer(fl)   # True

isclose随Python 3.5+附带,对于其他Python,您可以使用这个基本等效的定义(如相应的PEP中所述)

只是一个附加信息,is_integer在内部执行:

import math
isInteger = (math.floor(x) == x)

并不完全是在python中实现的,但cpython实现如上所述。

所有的答案都很好,但一个肯定的方法是

def whole (n):
     return (n*10)%10==0

如果是整数,函数返回True,否则返回False....我知道我有点晚了,但这是我做的一个有趣的方法。

编辑:正如下面的评论所述,一个更便宜的等效测试将是:

def whole(n):
    return n%1==0

检验立方根不是更简单吗?从20(20**3 = 8000)开始,到30(30**3 = 27000)。然后您必须测试少于10个整数。

for i in range(20, 30):
    print("Trying {0}".format(i))
    if i ** 3 > 12000:
        print("Maximum integral cube root less than 12000: {0}".format(i - 1))
        break

尝试使用:

int(val) == val

它比其他任何方法都更精确。