取余和取模

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

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

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

但是求模运算和求余运算在第一步不同: 求余运算在取c的值时,向0 方向舍入(int强制转换); 而取模运算在计算c的值时,向负无穷大方向舍入(floor()函数)。
因此,当a和b符号一致时,求模运算和求余运算所得的c的值一致,因此结果一致。但是当符号不一致的时候,结果不一样。

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

在C++中,%符号表示的是求余运算,在C++中没有取模运算符或者函数,需要自己实现。
取模运算函数

bool mod(int m, int n, int* pResult){
    if (n == 0)
        return false;
    double c = (double)m / n;
    *pResult = m - floor(c)*n;
    return true;
}

floor()函数向下取整,ceil()函数向上取整。包含在库文件cmath中

inline float floor(
   float _X
) restrict(amp);
inline double floor(
   double _X
) restrict(amp);



inline float ceil(
   float _X
) restrict(amp);
inline double ceil(
   double _X
) restrict(amp);

floor(),ceil()和Int强制转换:如果 Number 为负,则 Int 返回小于或等于 Number 的第一个负整数, 例如

int(-8.4)=-8;
ceil(-8.4) = -8;
floor(-8.4) = -9;

int(2.3) = 2;
ceil(2.3) = 3;
floor(2.3) = 2;

总之,int强制类型转换将浮点数向0取整,floor向负无穷大取整,ceil向正无穷大取整

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值