python – 如何获得立方根的整数?

python – 如何获得立方根的整数?,第1张

概述我正在创建一个问题,需要我找到某些数字的立方根,其中一些有整数根,但其中很多都没有. 我有像125这样的数字,应该返回5的立方根,但Python返回4.99999 例: >>> 125 ** (1.0/3.0)4.999999999999999 这是我的代码: processing = Truen = 12000while processing: if (n ** (1.0/3. 我正在创建一个问题,需要我找到某些数字的立方根,其中一些有整数根,但其中很多都没有.

我有像125这样的数字,应该返回5的立方根,但Python返回4.99999
例:

>>> 125 ** (1.0/3.0)4.999999999999999

这是我的代码:

processing = Truen = 12000while processing:    if (n ** (1.0/3.0)).is_integer() == True:        print((n ** (1.0/3.0)),"is the cube root of ",n)        processing = False    else:        n -= 1
解决方法 检查浮点相等性的标准方法是检查某个容差内的质量:

def floateq(a,b,tolerance=0.00000001):    return abs(a-b) < tolerance

现在,您可以检查多维数据集根的舍入,转换为整数版本是否等于某个容差内的多维数据集根本身:

def has_integer_cube_root(n):    floatroot = (n ** (1.0 / 3.0))    introot = int(round(floatroot))    return floateq(floatroot,introot)

用法:

>>> has_integer_cube_root(125)True>>> has_integer_cube_root(126)False

但是,对于您的用例,这是非常不精确的:

>>> has_integer_cube_root(40000**3)True>>> has_integer_cube_root(40000**3 + 1)True

您可以使用公差,但在某些时候,浮点数不足以获得所需的精度.

编辑:是的,正如评论所说,在这种情况下,您可以使用整数运算检查结果:

def has_integer_cube_root(n):    floatroot = (n ** (1.0 / 3.0))    introot = int(round(floatroot))    return introot*introot*introot == n>>> has_integer_cube_root(40000**3)True>>> has_integer_cube_root(40000**3 + 1)False
总结

以上是内存溢出为你收集整理的python – 如何获得立方根的整数?全部内容,希望文章能够帮你解决python – 如何获得立方根的整数?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/langs/1193038.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存