如何将十进制值舍入到最接近的0.05值?

时间:2009-09-19 12:25:22

标签: c# .net algorithm decimal rounding

有没有办法将十进制值四舍五入到.Net中的最接近的0.05?

前:

7.125 - > 7.15

6.66 - > 6.7

如果它现在可用,任何人都可以提供算法吗?

6 个答案:

答案 0 :(得分:27)

怎么样:

Math.Ceiling(myValue * 20) / 20

答案 1 :(得分:10)

使用此:

Math.Round(mydecimal / 0.05m, 0) * 0.05m;

可以在T-SQL中使用相同的逻辑:

ROUND(@mydecimal / 0.05, 0) * 0.05

我更喜欢selected answer的这种方法,因为你可以直接看到使用的精度。

答案 2 :(得分:5)

这样的事情应该适用于任何步骤,而不仅仅是0.05:

private decimal RoundUp (decimal value, decimal step)
{
    var multiplicand = Math.Ceiling (value / step);
    return step * multiplicand;
}

答案 3 :(得分:2)

Math..::.Round Method (Decimal, Int32, MidpointRounding)

将双精度浮点值舍入到指定的小数位数。如果值在两个其他数字之间的中间位置,则参数指定如何舍入值。

   Math.Round(1.489,2,MidpointRounding.AwayFromZero)

答案 4 :(得分:1)

ruby​​和python的重复herehere。它不应该太不同。

答案 5 :(得分:0)

在大多数公式中我无法得到适当的四舍五入

这一个“四舍五入”到最接近的

float roundFloat(float value, float toNearest) {
            float divVal = (1 / (toNearest == 0 ? 1 : toNearest));
            return ((float)(Math.Round(value * divVal)) / divVal);
        }

结果:

roundFloat(2, 0.125F); -> 2
roundFloat(2.11, 0.125F); -> 2.125
roundFloat(2.22, 0.125F); -> 2.25
roundFloat(2.33, 0.125F); -> 2.375
roundFloat(2.44, 0.125F); -> 2.5
roundFloat(2.549999, 0.125F); -> 2.5
roundFloat(2.659999, 0.125F); -> 2.625
roundFloat(2.769999, 0.125F); -> 2.75
roundFloat(2.879999, 0.125F); -> 2.875
roundFloat(2.989999, 0.125F); -> 3

示例0.125最接近的四舍五入

 2.000 
 2.125 
 2.250 
 2.375 
 2.500 
 2.625 
 2.750 
 2.875 
 3.000