首页  >  文章  >  后端开发  >  在 C 中如何有效地将数字四舍五入到最接近的倍数?

在 C 中如何有效地将数字四舍五入到最接近的倍数?

Susan Sarandon
Susan Sarandon原创
2024-11-26 14:04:13267浏览

How Can I Efficiently Round Up Numbers to the Nearest Multiple in C  ?

在 C 中舍入为数字的倍数

在编程中处理数字时,可能需要将值舍入为另一个数字最接近的倍数。在 C 中,有多种方法可以完成此任务,但本文将重点介绍一种利用整数算术实现精确舍入的有效方法。

提供的代码片段 roundUp 为正数提供了一种简单的解决方案。它计算输入数字 numToRound 除以倍数时的余数,如果余数非零,则将倍数与 numToRound 相加。这可确保结果是大于或等于输入的最接近倍数。

但是,对于负数,原始代码无法提供所需的行为。为了容纳负数,引入了 roundUp 的修改版本。该版本在执行舍入操作之前计算输入数字的绝对值。此外,它还采用条件逻辑根据输入的符号调整结果的符号。这可确保结果始终大于或等于输入,无论其符号如何。

以下是处理正数和负数的更新代码:

int roundUp(int numToRound, int multiple)
{
    if (multiple == 0)
        return numToRound;

    int remainder = abs(numToRound) % multiple;
    if (remainder == 0)
        return numToRound;

    if (numToRound < 0)
        return -(abs(numToRound) - remainder);
    else
        return numToRound + multiple - remainder;
}

现在, roundUp 函数为正数和负数输入提供一致的行为,确保精确舍入到给定数字的最接近的倍数。

以上是在 C 中如何有效地将数字四舍五入到最接近的倍数?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn