取模运算和求余运算的区别

取模与求余运算的区别详解
编程中,取模运算(mod)和求余(rem)运算常被混淆,主要区别在于处理负数时的舍入规则。取模运算在计算整数商时向0舍入,而求余运算则向负无穷舍入。当操作数符号不同时,两者结果不同,求模结果符号与除数b一致,求余结果符号与被除数a一致。在C语言中'%'表示求余,Python中'%'则表示取模,且Python允许负数参与取模运算。

通常情况下取模运算(mod)和求余(rem)运算被混为一谈,因为在大多数的编程语言里,都用'%'符号表示取模或者求余运算。在这里要提醒大家要十分注意当前环境下'%'运算符的具体意义,因为在有负数存在的情况下,两者的结果是不一样的。


对于整型数a,b来说,取模运算或者求余运算的方法都是:

1.求 整数商: c = a/b;

2.计算模或者余数: r = a - c*b.


求模运算和求余运算在第一步不同: 取模求余运算在取c的值时,向0 方向舍入(fix()函数);求余取模运算在计算c的值时,向无穷小方向舍入(floor()函数)。

因此,当a和b符号一致时,求模运算和求余运算所得的c的值一致,因此结果一致。但是当符号不一致的时候,结果不一样。

具体来说,求模运算结果的符号和b一致,求余运算结果的符号和a一致


在C语言中,%符号表示的是求余运算,在python脚本中,%表示的是取模。(通常取模运算中b不允许是负数,但是在python 2.5.1里可以在%后面跟负数,因为python语言中除法的结果是向0舍入,因此计算结果是取模!)

下面表格是一些典型的取模或者求余的值。

     a   
   b   
C语言:a%b   (求余)
Python Shell: a%b(取模)
-3-5-3-3
-34-31
-32-11
-16-15
-4-3-1-1
2422
5322
4-74-3
4-31-2
-6-5-1-1





C++中模运算本质上是两个数相除的数。在数学上,对于两个整数ab(b 不为 0),模运算可以表示为:a = q * b + r,其中q是商,r是数(即的结果),并且0 ≤ |r| < |b| 。 使用方法上,操作必须对两个整型变量进行,不能有小数。以下是使用示例: ```cpp #include <iostream> int main() { int a = 5; int b = 2; std::cout << a % b; // 输出为 1 return 0; } ``` 在这个例子中,5 除以 2 商为 2,数为 1,所以结果为 1。 在使用 C++ 模运算时,有以下注意事项: - 当 0 参与运算时,若 0 作为除数,此时编译不通过;若 0 作为被除数,对非零数,得到的结果总为 0。例如: ```cpp #include <iostream> int main() { int c = 2; int d = 0; // 0 作为被除数 std::cout << d % c; // 输出 0 return 0; } ``` - 时不能有小数参与,两个小数不能进行模运算,整数小数也不能进行模运算。例如: ```cpp #include <iostream> int main() { double a = 3.14; double b = 1.1; int c = 2; // 以下这些操作都会产生编译错误 std::cout << a % c; // Invalid operands to binary expression ('double' and 'int') std::cout << c % a; // Invalid operands to binary expression ('int' and 'double') std::cout << a % b; // Invalid operands to binary expression ('double' and 'double') return 0; } ``` - 除法的被除数不能为0,若在模运算里将 0 作为除数,编译会不通过。 - 两个整数相除依然是整数,小数部分舍弃,但模运算本身是基于整数的操作,与整数相除结果的整规则相关但关注点不同。
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值