VB6 Round(x,0)问题

时间:2016-11-11 13:11:56

标签: vb6 rounding

很久以前我的公司出现了意想不到的结果,我发现了这个问题:

Dim k As Double
Dim r As Integer
k = 182.5
r = Round(k,0)

r的结果是182,这给我的公司带来了问题,现在我必须解决它。

事情就是我观察到了这一点:

Dim k As Double
Dim r As Integer
k = 186.5
r = Round(k,0)

r = 187

当double的整数部分的unities大于5时,Round会按照我的预期进行,但对于unities< = 5则不会。

我该如何解决这个问题?是否有其他功能可以获得正确的舍入?

2 个答案:

答案 0 :(得分:5)

这称为银行家四舍五入,并尝试根据最接近的数字是奇数还是偶数来分配.5的上/下舍入。

围绕.5:

cint(format(182.5, "#0")) ''183
cint(format(186.5, "#0")) ''187

答案 1 :(得分:1)

嗯,首先,你说不是这样。

k = 182.5
r = Round(k, 0)

确实会产生182,但

k = 186.5
r = Round(k, 0)
如你所说,

将产生186,而不是187。现在,

k = 185.5
r = Round(k, 0)

也会产生186。这称为Banker's Rounding,是VB6中的标准。目的是消除始终围绕一个完全中间的偏见。

如果您想要始终向上舍入0.5,请使用

k = 186.5
r = Int(k * 2 + 1) \ 2

如果你想总是向下舍入0.5,你可以使用

k = 186.5
r = Int(k * 2 + 0.99) \ 2

添加尽可能多的9,因为小数点后面有有效数字。