C/C++ 深度理解 取余/取模

本文探讨了编程中浮点数取整的不同规则,包括0向取整、正无穷取整和负无穷取整,并强调了浮点数取模与取余的区别,指出当商为负数时取模与取余不等价。通过实例和Python、C++对比,揭示了两者在实际操作中的行为差异。
摘要由CSDN通过智能技术生成

目录


前言

本文介绍了编程语言取模和取余之间的区别和需要注意的细节。


一、浮点数取整规则

C/C++ 中的浮点数取整是按照 0向取整的方式截取,把小数点后所有位直接抛弃。
在这里插入图片描述

	int i = 10 / -3; //i = -3.33333...

大多数语言,对于浮点数取整运用的都是以下几种方式:


0向取整

在这里插入图片描述

正无穷取整

在这里插入图片描述

负无穷取整

在这里插入图片描述

四舍五入

C语言提供了 round() 函数对浮点数取整。
在这里插入图片描述




二、取模

如果a和d是两个自然数,d非零,可以证明存在两个唯一的整数,q 和 r,满足 : a = q*d + r 并且 0 <= r < d ,其中,q 为商,r 为 余数

int main()
{
	int a = -10;
	int d = 3;
	
	cout << a % d; //result = -1
	//a = q*d + r
	//-10 = 3 * -3  + -1 
}

可以得知,余数的值取决于商,而商的值取决于这个语言的浮点数取整方式。



在python3测试

import sys
if True :

	aaa=-10 % 3
	print(aaa)  //result  =  2
	//a = q*d + r
	//-10 = 3 * -4  + 2  由余数为2可以求出,商为-4

可以得知,python的浮点数的取整方式是负无穷取整, -3.3333… 取整为 -4 。概念上符合余数的定义 必须大于等于0小于除数。


结论

**在这里插入图片描述



取余和取模不一样

取余是让商向0取整,取模是让商向负无穷取整。

当商为正数时,取模等价取余,因为商为正数时,其0向取整和负无穷取整的方向是相同的。
当商为负数时,取模不等价取余,其取整方向相反。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

necesse

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值