负数取模

参考这里写链接内容
一、自然数的取模运算的定义是这样的
定义1:
如果a和d是两个自然数,d非零,可以证明存在两个唯一的整数 q 和 r,满足 a = qd + r 且0 ≤ r < d。其中,q 被称为商,r 被称为余数。
定义2:
如果a 与d 是整数,d 非零,那么余数 r 满足这样的关系:
a = qd + r , q 为整数,且0 ≤ |r| < |d|。
二、
(1)对于任何同号的两个整数,其取余结果没有争议,所有语言的运算原则都是使商尽可能小。
(2)对于异号的两个整数,C++/Java语言的原则是使商尽可能大,很多新型语言和网页计算器的原则是使商尽可能小
那么对于负数,是否可以沿用这样的定义呢?我们发现,假如我们按照正数求余的规则求 (-7) mod 3 的结果,就可以表示 -7 为 (-3)* 3 +2。其中,2是余数,-3是商。
那么,各种编程语言和计算器是否是按照这样理解的呢?下面是几种软件中对此的理解。
C++(G++ 编译): cout << (-7) % 3; // 输出 -1
Java(1.6): System.out.println((-7) % 3); // 输出 -1
Python 2.6:>>> (-7) % 3 // 输出 2
百度计算器:(-7) mod 3 = 2
Google 计算器:(-7) mod 3 = 2
有道计算器:(-7) mod 3 = -1

根据定义2,7 = (-3) * (-2) + 1 或7 = (-3) * (-3) -2,所以余数为 1 或 -2。
C++(G++ 编译): cout << 7 % (-3); // 输出 1
Java(1.6): System.out.println(7 % (-3)); // 输出 1
Python 2.6:>>> 输出 -2
百度计算器:7 mod (-3) = -2
Google 计算器: 7 mod (-3) = -2
有道计算器:不支持
C++(G++ 编译): cout << (-7) % (-3); // 输出 -1
Java(1.6): System.out.println((-7) % (-3)); // 输出 -1
Python 2.6:>>> 输出 -1
百度计算器:-7 mod (-3) = -1
Google 计算器: -7 mod (-3) = -1
结果让人大跌眼镜,所有语言和计算机返回结果完全一致。
总结时间到

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值