我该如何处理非负模型?

时间:2011-10-13 23:12:24

标签: java modulo

当我在Java程序中使用运算符%时,我不断得到否定答案。示例:-1%100给出-1。虽然这在数学上是正确的,但我想得到正常的数学解,或99.换句话说,我想得到最小的正整数解。在Java中是否有任何简单的解决方案(也许我在Math中忽略了什么? - 我找不到它)?

我还想澄清一下,如果API中有某些内容可以做到这一点,那么链接就会很棒。

4 个答案:

答案 0 :(得分:3)

你可以这样做吗?

int d = 100;

int x = -1 % d;
if (x < 0)
    x += d;

这适用于任何积极的d

答案 1 :(得分:2)

您可以执行以下操作

int myMod(int x, int modulo)
{
   return ((x % modulo) + modulo)  % modulo
}

答案 2 :(得分:0)

这适用于代替d或x的任何值。

int d=100;
int x=-1%d;
while (x<0)
    x+=d;

答案 3 :(得分:0)

i < 0 ? n - ((-i - 1) % n + 1) : i % n

例如:

class Mod {
  public static int mod(int i, int n) {
    return i < 0 ? n - ((-i - 1) % n + 1) : i % n;
  }

  public static void main(String [] args) {
    System.out.println("mod(-201, 100) == " + mod(-201, 100));
    System.out.println("mod(-200, 100) == " + mod(-200, 100));
    System.out.println("mod(17, 100) == " + mod(17, 100));
    System.out.println("mod(100, 100) == " + mod(100, 100));
  }
}

$ javac Mod.java && java Mod
mod(-201, 100) == 99
mod(-200, 100) == 0
mod(17, 100) == 17
mod(100, 100) == 0

没有循环。