提问人:Adam Nelson 提问时间:6/2/2010 最后编辑:mkrieger1Adam Nelson 更新时间:3/18/2022 访问量:437901
为什么除法四舍五入为整数?[复制]
Why does the division get rounded to an integer? [duplicate]
问:
我试图将一组从 -100 到 0 的数字归一化为 10-100 的范围,但遇到了问题,只是注意到即使根本没有变量,这也不会像我期望的那样评估它:
>>> (20-10) / (100-10)
0
浮点除法也不起作用:
>>> float((20-10) / (100-10))
0.0
如果分割的任一侧被投射到浮点数上,它将起作用:
>>> (20-10) / float((100-10))
0.1111111111111111
第一个示例中的每一边都计算为 int,这意味着最终答案将转换为 int。 由于 0.111 小于 .5,因此四舍五入为 0。在我看来,这并不透明,但我想就是这样。
解释是什么?
答:
在进行除法之前,您需要将其更改为浮点数。那是:
float(20 - 10) / (100 - 10)
评论
无论哪种方式,它都是整数除法。10/90 = 0。在第二种情况下,您只是将 0 转换为浮点数。
尝试将“/”的操作数之一转换为浮点数:
float(20-10) / (100-10)
在第二个示例中,在除法已经发生之后,您正在强制转换为浮动。试试这个:
float(20-10) / float(100-10)
>>> 10 / 90
0
如果之后将其转换为浮点数,则舍入已经完成,换句话说,0 整数将始终变为 0 浮点数。
如果你在除法的任一侧使用浮点数,那么 Python 会给你你期望的答案。
>>> 10 / 90.0
0.1111111111111111
因此,就您而言:
>>> float(20-10) / (100-10)
0.1111111111111111
>>> (20-10) / float(100-10)
0.1111111111111111
您使用的是 Python 2.x,其中整数除法将被截断,而不是成为浮点数。
>>> 1 / 2
0
您应该将其中一个设为:float
>>> float(10 - 20) / (100 - 10)
-0.1111111111111111
或者,强制采用 Python 3.x 的行为,该行为总是返回浮点数。from __future__ import division
/
>>> from __future__ import division
>>> (10 - 20) / (100 - 10)
-0.1111111111111111
评论
from __future__ import division
1 // 2
__future__
//
__floordiv__()
__future__.division
让其中至少一个浮点,那么它将是浮点除法,而不是整数:
>>> (20.0-10) / (100-10)
0.1111111111111111
将结果转换为浮动为时已晚。
通过在数字后放置“.”来指定浮点数也会导致其默认为浮点数。
>>> 1 / 2
0
>>> 1. / 2.
0.5
它与您使用的 python 版本有关。基本上它采用 C 行为:如果将两个整数相除,结果将向下舍入为整数。还要记住,Python 从左到右执行操作,这在您打字时会发挥作用。
例: 由于这是我在进行算术运算时总是出现在我脑海中的问题(我应该转换为浮点数以及哪个数字),因此提供了这方面的一个例子:
>>> a = 1/2/3/4/5/4/3
>>> a
0
当我们除以整数时,四舍五入也就不足为奇了。
>>> a = 1/2/3/4/5/4/float(3)
>>> a
0.0
如果我们将最后一个整数类型转换为浮点数,我们仍然会得到零,因为当我们的数字除以浮点数时,由于整数除法,浮点数已经变为 0。
>>> a = 1/2/3/float(4)/5/4/3
>>> a
0.0
与上面的情况相同,但将浮点类型转换移近左侧。
>>> a = float(1)/2/3/4/5/4/3
>>> a
0.0006944444444444445
最后,当我们将第一个整数键入为浮点数时,结果是所需的,因为从第一个除法开始,即最左边的整数,我们使用浮点数。
额外 1:如果您想回答这个问题以改进算术评估,您应该检查此内容
额外 2:请注意以下情况:
>>> a = float(1/2/3/4/5/4/3)
>>> a
0.0
在 Python 2.7 中,如果输入是整数,则运算符是整数除法:/
>>>20/15
1
>>>20.0/15.0
1.33333333333
>>>20.0/15
1.33333333333
在 Python 3.3 中,即使输入是整数,运算符也是浮点除法。/
>>> 20/15
1.33333333333
>>>20.0/15
1.33333333333
对于 Python 3 中的整数除法,我们将使用运算符。//
运算符是 Python 2.7 和 Python 3.3 中的整数除法运算符。//
在 Python 2.7 和 Python 3.3 中:
>>>20//15
1
现在,看看比较
>>>a = 7.0/4.0
>>>b = 7/4
>>>print a == b
对于上面的程序,输出在 Python 2.7 中为 False,在 Python 3.3 中为 True。
在 Python 2.7 中,a = 1.75 和 b = 1。
在 Python 3.3 中,a = 1.75 和 b = 1.75,只是因为是浮点除法。/
我有点惊讶,没有人提到原来的发帖人可能喜欢有理数的结果。如果您对此感兴趣,基于 Python 的程序 Sage 会为您提供支持。(目前仍基于 Python 2.x,但 3.x 正在进行中。
sage: (20-10) / (100-10)
1/9
这不是适合所有人的解决方案,因为它确实做了一些准备,所以这些数字不是 s,而是 Sage 类元素。尽管如此,值得一提的是,作为 Python 生态系统的一部分。int
Integer
就我个人而言,我更喜欢在一开始就插入一个。所以表达式变成这样:1. *
1. * (20-10) / (100-10)
正如我总是对一些公式进行除法一样:
accuracy = 1. * (len(y_val) - sum(y_val)) / len(y_val)
所以不可能简单地添加一个喜欢.就我而言,用 a 包装可能会失去一点可读性。.0
20.0
float()
在 python 中没有更新除法计算。因此,您必须包含在程序的第一行。cv2
from __future__ import division
在 Python 3 中,“//”运算符用作整数和浮点参数的楼层划分。但是,如果其中一个参数是浮点数,运算符 / 将返回浮点值(这类似于 C++)
例如:
# A Python program to demonstrate the use of
# "//" for integers
print (5//2)
print (-5//2)
输出:
2
-3
# A Python program to demonstrate use of
# "/" for floating point numbers
print (5.0/2)
print (-5.0/2)
输出:
2.5
-2.5
编号: https://www.geeksforgeeks.org/division-operator-in-python/
评论
float
float