取余与取模的区别,以及在C++(C#)中的使用

c++和C#中,运算符‘%’为取余运算符,而并非取模预算符,在一些应用场景中,如果不加以区分,会产生严重的bug。

取余运算(Complementation)和取模运算(Modulo Operation)的区别:
对于整型数a,b来说,取模运算或取余运算的方法都是:
第一步:求 整数商: c = a/b;
第二步:计算模或者余数: r = a - c*b.
两者的区别在于第一步:
取余运算在取c的值时,向0 方向舍入(fix()函数);
取模运算在计算c的值时,向负无穷方向舍入(floor()函数)。
例如:a = -7,b = 4
第一步:求整数商c,求余c = -1(向0方向舍入),求模运算c = -2(向负无穷方向舍入);
第二步:计算模和余数的公式相同,但因c的值不同,求余时r = -3,求模时r = 1。

需要特别注意的是:c++和C#中,运算符‘%’是取余运算符
c++ 示例代码

std::cout << "c++ 中‘%’运算符完成取余运算,而非取模运算" << std::endl;
a = -7;
r = a%b;
std::cout << a << " % " << b << " = " << r << std::endl;

std::cout << "------------取模运算---------------------" << std::endl;
double ad = a;
double cd = floor(ad / b); //向负无穷方向舍入
r = ad - cd*b;
std::cout << ad << " mod " << b << " = " << r << std::endl;

运行结果
这里写图片描述
完整代码示例下载:http://download.csdn.net/download/xingao0114/10140395

猜你喜欢

转载自blog.csdn.net/xingao0114/article/details/78683827