将整数舍入到最接近的10的倍数

时间:2013-03-01 09:30:03

标签: c# currency rounding

我想弄清楚如何围绕价格 - 两种方式。例如:

Round down
43 becomes 40
143 becomes 140
1433 becomes 1430

Round up
43 becomes 50
143 becomes 150
1433 becomes 1440

我的情况是我的价格范围是:

£143 - £193

我想表现为:

£140 - £200

因为它看起来更清洁

关于如何实现这一目标的任何想法?

6 个答案:

答案 0 :(得分:58)

我只想创建几个方法;

int RoundUp(int toRound)
{
     if (toRound % 10 == 0) return toRound;
     return (10 - toRound % 10) + toRound;
}

int RoundDown(int toRound)
{
    return toRound - toRound % 10;
}

模数给出了余数,在四舍五入的情况下10 - r将你带到最接近的十分之一,向下舍入你只需减去r。很直接。

答案 1 :(得分:15)

您不需要使用模数(%)或浮点数......

这有效:

public static int RoundUp(int value)
{
    return 10*((value + 9)/10);
}

public static int RoundDown(int value)
{
    return 10*(value/10);
}

答案 2 :(得分:10)

此代码舍入到最接近的10的倍数:

int RoundNum(int num)
{
     int rem = num % 10;
     return rem >= 5 ? (num - rem + 10) : (num - rem);
}

非常简单的用法:

Console.WriteLine(RoundNum(143)); // prints 140
Console.WriteLine(RoundNum(193)); // prints 190

答案 3 :(得分:4)

将数字除以10。

number = number / 10;
Math.Ceiling(number);//round up
Math.Round(number);//round down

然后乘以10。

number = number * 10;

答案 4 :(得分:4)

将数字舍入为另一个数字的倍数的一般方法,舍入away from zero

对于整数

int RoundNum(int num, int step)
{
    if (num >= 0)
        return ((num + (step / 2)) / step) * step;
    else
        return ((num - (step / 2)) / step) * step;
}

适用于浮动

float RoundNum(float num, float step)
{
    if (num >= 0)
        return floor((num + step / 2) / step) * step;
    else
        return ceil((num - step / 2) / step) * step;
}

我知道某些部分可能看起来违反直觉或不太优化。我尝试将(num + step / 2)转换为int,但是这给出了负浮动((int) -12.0000 = -11等)的错误结果。无论如何,这些是我测试的几个案例:

  • 四舍五入到第1步的任何数字都应该是
  • -3四舍五入到步骤2 = -4
  • -2四舍五入到第2步= -2
  • 3舍入到步骤2 = 4
  • 2舍入到步骤2 = 2
  • -2.3四舍五入到步骤0.2 = -2.4
  • -2.4四舍五入到步骤0.2 = -2.4
  • 2.3舍入到步骤0.2 = 2.4
  • 2.4舍入到步骤0.2 = 2.4

答案 5 :(得分:0)

public static int Round(int n)
        {
            // Smaller multiple 
            int a = (n / 10) * 10;

            // Larger multiple 
            int b = a + 10;

            // Return of closest of two 
            return (n - a > b - n) ? b : a;
        }
相关问题