有没有办法将十进制值四舍五入到.Net中的最接近的0.05?
前:
7.125 - > 7.15
6.66 - > 6.7
如果它现在可用,任何人都可以提供算法吗?
答案 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)
答案 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