取模运算在数学定义与机器理解的区别

本文探讨了在C语言中,取模运算(mod)的数学定义与机器实现的区别。数学上,取模运算可以通过商和余数表示,如x mod y = x - y * [x/y],而机器中使用的是地板除法。举例说明了两者在处理浮点数除法时的不同,强调在编程时要注意这种差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

纪念我c语言第一次课堂作业被坑

取模运算(“MOD”)

数学定义:

谷歌到《Concrete Mathematics》上的一段,原文:

摘自P82:

3.4 ‘MOD’: THE BINARY OPERATION
The quotient of n divided by m is [n/m],when m and n are positive
integers. It’s handy to have a simple notation also for the remainder
of this division, and we call it ‘n mod m’, The basic formula
n = m[n/m]+ n mod m
//NOTE:”m[n/m]” is quotient, “n mod m” is remainder
tells us that we can express n mod m as n-m[n/m] .We can generalize this
to megative integers, and in fact to arbitrary real numbers:

x mod y = x - y[x/y], for y!=0.

在这里的余数(Remainder)其实就是取模(mod):x mod y=x % y=x-y(x/y),for y!=0.

在概念上数和机器的理解是相同的,然鹅……机器在实现上确是与数学有差异。

1.数学上:[x/y]为x/y的最小下界
举个栗子:
5 mod 2=5 - 2 * [5/2]
=5 - 2 * [2.5]
=5 - 2 * 2
=1
2.机器上:[x/y]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值