如何在Java中舍入整数除法并得到int结果?

bla*_*sei 81 java math formatting types

我只是写了一个小方法来计算手机短信的页数.我没有选择使用Math.ceil,老实说它似乎非常难看.

这是我的代码:

public class Main {

/**
 * @param args the command line arguments
 */
public static void main(String[] args) {
   String message = "today we stumbled upon a huge performance leak while optimizing a raycasting algorithm. Much to our surprise, the Math.floor() method took almost half of the calculation time: 3 floor operations took the same amount of time as one trilinear interpolation. Since we could not belive that the floor-method could produce such a enourmous overhead, we wrote a small test program that reproduce";

   System.out.printf("COunt is %d ",(int)messagePageCount(message));



}

public static double messagePageCount(String message){
    if(message.trim().isEmpty() || message.trim().length() == 0){
        return 0;
    } else{
        if(message.length() <= 160){
            return 1;
        } else {
            return Math.ceil((double)message.length()/153);
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

我真的不喜欢这段代码,我正在寻找一种更优雅的方式.有了这个,我期待3而不是3.0000000.有任何想法吗?

小智 151

使用Math.ceil()并将结果转换为int:

  • 这仍然比使用abs()避免双倍更快.
  • 使用底片时结果是正确的,因为-0.999将向上舍入为0

例:

(int) Math.ceil((double)divident / divisor);
Run Code Online (Sandbox Code Playgroud)

  • 这应该是正确的答案 (7认同)
  • 这应该是正确答案?包括浮点计算不会包括一些非直观的边缘情况和各种问题,只是为了对简单的整数除法进行舍入?通常为了否定浮动问题,人们使用 double 来代替,这只会让问题不那么突出,但并不能解决它们 https://introcs.cs.princeton.edu/java/91float/ (3认同)
  • 公平的观点,尽管我认为这是现在在Google上热门的“数学取整”:可耻的是它有这样的条件。 (2认同)

Pet*_*rey 106

要整数整数除法,您可以使用

import static java.lang.Math.abs;

public static long roundUp(long num, long divisor) {
    int sign = (num > 0 ? 1 : -1) * (divisor > 0 ? 1 : -1);
    return sign * (abs(num) + abs(divisor) - 1) / abs(divisor);
}
Run Code Online (Sandbox Code Playgroud)

或两个数字都是正数

public static long roundUp(long num, long divisor) {
    return (num + divisor - 1) / divisor;
}
Run Code Online (Sandbox Code Playgroud)

  • @DougEnglish那是因为你错过了静态导入. (10认同)
  • 我的意思是,尝试`num = -2`和`div = -3`.最终以"-6/-3 = 2"结束,但是"0,666 ......"应该舍入为"1".事实上它不适用于`num <= 0 && div <= 0`. (2认同)
  • 我的编译器无法识别abs() - 我不得不使用Math.abs()... (2认同)
  • 在此(第二个)函数中,您需要 num + 除数 -1 &lt;= Long.MAX_VALUE。有一个(是不是更慢?)函数没有这个限制:(num / divisor) + (num % divisor == 0 ? 0 : 1)。 (2认同)

pop*_*str 38

另一个不太复杂的单线程:

private int countNumberOfPages(int numberOfObjects, int pageSize) {
    return numberOfObjects / pageSize + (numberOfObjects % pageSize == 0 ? 0 : 1);
}
Run Code Online (Sandbox Code Playgroud)

可以使用long而不是int; 只需更改参数类型和返回类型.

  • 这应该是答案.它可能是最简单的实现方法,并且避免不执行任何额外的不必要步骤.当转换为不同的数字类型时,它还避免了一些小的添加问题. (4认同)

Ste*_*ler 18

Google的Guava库在IntMath类中处理这个问题:

IntMath.divide(numerator, divisor, RoundingMode.CEILING);
Run Code Online (Sandbox Code Playgroud)

与此处的许多答案不同,它处理负数.当尝试除以零时,它也会抛出适当的异常.


dee*_*see 12

(message.length() + 152) / 153
Run Code Online (Sandbox Code Playgroud)

这将给出一个"向上舍入"的整数.


mek*_*azu 8

long numberOfPages = new BigDecimal(resultsSize).divide(new BigDecimal(pageSize), RoundingMode.UP).longValue();
Run Code Online (Sandbox Code Playgroud)