通常取模运算也叫取余运算,它们返回的结果都是余数。rem(取余)和mod(取模)唯一的区别在于:当X和Y的正负号一样的时候,两个函数结果是等同的;当X和Y的符号不同时,rem(取余)函数的结果的符号和X的符号一样,而mod(取模)函数的结果符号和Y的符号一样。
这是由于这两个函数的生成机制不同,rem函数采用fix函数,而mod函数采用了floor函数(这两个函数是用来取整的,fix函数向0方向舍入,floor函数向无穷小的方向舍入)。rem(x, y)函数返回的是x-n.*y,如果y不等于0,其中的 n = fix(x./y),而mod(x, y)返回的是 x-n.*y,当y不等于0时,n = floor(x./y)
Java 示例
public class Test07 {
public static void main(String[] args) {
System.out.println("7对3取余:" + 7 % 3);
System.out.println("7对-3取余:" + 7 % (-3));
System.out.println("-7对3取余:" + (-7) % 3);
System.out.println("-7对-3取余:" + (-7) % (-3));
System.out.println("\n\n");
System.out.println("7对3取模:" + Math.floorMod(7, 3));
System.out.println("7对-3取模:" + Math.floorMod(7, -3));
System.out.println("-7对3取模:" + Math.floorMod(-7, 3));
System.out.println("-7对-3取模:" + Math.floorMod(-7, -3));
}
}
输出结果:
7对3取余:1
7对-3取余:1
-7对3取余:-1
-7对-3取余:-1
7对3取模:1
7对-3取模:-2
-7对3取模:2
-7对-3取模:-1
解析:
上面提到,rem采用fix(向0取整);mod采用floor(向无穷小取整)
因为在matlab中,关于取余和取模是这样定义的:
当y ≠ 0 时
取余:rem(x,y) = x-y.*fix(x./y)
取模:mod(x,y) = x-y.*floor(x./y)
符号一致时:
7/3 = 2.33,或者 (-7)/(-3) = 2.33 产生了两个商2和3
fix(2.33) = 2 (向0取整)
floor(2.33) = 2 (向小的方向取整)
rem(7,3) = 7 - 3*2 = 1
mod(7,3) = 7 - 3*2 = 1
rem(-7,-3) = (-7) - (-3)*2 = -1
mod(-7,-3) = (-7) - (-3)*2 = -1
符号不一致时:
7/(-3) = -2.33,或者 (-7)/3 = -2.33 产生了两个商-2和-3
fix(-2.33) = -2 (向0取整)
floor(-2.33) = -3 (向小的方向取整)
rem(7,-3) = 7 - (-3)*(-2) = 1
mod(7,-3) = 7 - (-3)*(-3) = -2
rem(-7,3) = (-7) - 3*(-2) = -1
mod(-7,3) = (-7) - 3*(-3) = 2
总结:
1. 取余,遵循尽可能让商向0方向靠近的原则;取模,遵循尽可能让商向负无穷靠近的原则
2. 符号相同时,两者的值不会冲突,都是一样的;符号不同时,两者回产生冲突
3. 取余运算结果的符号和被除数的符号保持一致;取模运算结果的符号和除数的符号保持一致。