在Python中检查整除性:不同的视角
当面临确定一个数字是否可以被另一个数字整除的任务时,许多开发人员本能地诉诸除法并检查余数。然而,这种方法可能会导致陷阱,特别是在 Python 对除法的不同解释的情况下。
在 Python 2.x 中,默认行为是整数除法,它会丢弃余数。这意味着除法运算符将始终产生一个整数,无论是否存在非零余数。因此,使用 isinstance 测试整数并不能提供有意义的区分。
另一方面,在 Python 3.x 中,除法默认为浮点运算,甚至会生成浮点值整数。因此,即使数字在数学意义上可整除,isinstance 检查也会失败。
更好的路径:救援模数运算符
更有效的方法是使用模运算符%。当且仅当 n 能被 k 整除时,表达式 n % k == 0 返回 True。此方法直接解决整除性标准,而不存在与除法相关的歧义。
示例解决方案
有了这些知识,让我们修改您的代码以正确测试整除性:
n = 0
s = 0
while n 此解决方案使用模运算符来检查能否被 3 和 5 整除,从而有效地过滤掉满足任一条件的数字。其结果是为您的原始问题提供更精确、更稳健的解决方案。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3