17个点五个五个排列,可以排3列,剩余两个。用带余除法来说,17除以5等于3,余数是2.
带余除法,也称为欧几里德除法(英語:Euclidean division)是数学中的一种基本算术计算方式。给定一个被除数
和一个除数
,带余除法给出一个整数
和一个介于一定范围的余数
,使得下面等式成立:
![{\displaystyle a=bq+r}](https://wikimedia.org/api/rest_v1/media/math/render/svg/ff37cbe024f8cc6ff961323bde02fb9c5d32066e)
一般所称“欧几里德除法”,限定余数的范围在0与
之间。还有叫做“居中除法”的变体,限定余数在
与
之间,这种余数称为“居中余数”。这样的限定都是为了使得满足等式的
有且仅有一个。这时候的
称为带余除法的商。带余除法一般表示为:
![{\displaystyle a\div b=q\dots r}](https://wikimedia.org/api/rest_v1/media/math/render/svg/a03c05c48799576ee11a895866c70c91c780949b)
表达为:“
除以
等于
,余
”。最常见的带余除法是整数与整数的带余除法(被除数a和除数b都是整数),但实数与整数乃至实数与实数的带余除法也有应用。对一般的抽象代数系统,能够进行带余除法的都是具有欧几里德性质的系统。如果余数为零,则称
整除
。一般约定除数
不能为0。
带余除法的计算有长久的历史,有各种计算工具和计算方法。最常用的是长除法(竖式除法)。带余除法在数论中有不少用途,比如说辗转相除法的基本步骤就是带余除法。
例子
如何将30个苹果尽可能地分给7个人,并且使每人一样多?
以下是整数带余除法的例子:依照公历,一年中的四月份有30天。每星期有7天,从四月的第一天开始,可以数出有四个星期,此外还有2天。如果要数出5个星期,则还差了5天。带余除法表示,就是:
![{\displaystyle 30\div 7=4\dots 2}](https://wikimedia.org/api/rest_v1/media/math/render/svg/d11d6154ba98c94201a946fcedb9ac0d86c9ebfb)
里面的30是被除数,7是除数,4是带余除法得到的商,2是带余除法得到的余数。日常生活中说:“四月份有四个多星期”,是带余除法的结果。
另一个例子是分配问题。假设有30个苹果要分给7个人,每人分的要一样多,那么可以使用带余除法:
![{\displaystyle 30\div 7=4\dots 2}](https://wikimedia.org/api/rest_v1/media/math/render/svg/d11d6154ba98c94201a946fcedb9ac0d86c9ebfb)
这说明每人可以分到4个,还剩余2个。如果每人分5个,则是不够的。每人如果只分3个,则还剩余9个,可以继续分。带余除法说明了在人人分到的要一样多的条件下,每人可以分到的最多苹果数目。
不同的带余除法
最基本的带余除法是整数与整数的带余除法,这时商和余数都是整数。实数与整数的带余除法,或实数与实数的带余除法,余数是实数,但不一定是整数。比如说讨论使用正弦函数构造的数列
时,就需要使用除数为
的带余除法,来讨论每一项具体的取值。
基本定理
带余除法限定了余数的范围,使得商唯一存在。整数与整数的带余除法中,余数的范围通常是
这样的
个元素的集合。被除数为实数的带余除法中,常常会使用介于0和除数
之间(大于等于0,严格小于
)的半开闭区间作为余数的范围;另一种常见的范围是大于等于
,严格小于
。带余除法的基本定理说明:整数与整数的带余除法中,只要余数的范围是
个整数,并且任何两个数之差都不是b的倍数,那么带余除法的商唯一存在;被除数为实数的除法中,只要余数的范围是一个如同长度为
的半开半闭区间,那么带余除法的商唯一存在。[1]:25
最常见的带余除法中用到的是整数除以整数的一个版本:
证明
定理的证明是将整数集合或实数轴分割成长度为|b|的区间段。證明由兩部分組成 - 首先證明
和
的存在性,其次證明
和
的唯一性。
整数除以整数的情况:
假设余数的范围是
,其中任两个数的差都不是
的倍数。那么可以将全体整数分割成以下集合的不交并集:
![{\displaystyle \mathbb {Z} =\sqcup _{k\in \mathbb {Z} }\{r_{1}+kb,r_{2}+kb,\dots ,r_{|b|}+kb\}=\sqcup _{k\in \mathbb {Z} }R_{k}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/6f02b01f11be2d9d2ad4f15f885c2ab27f89bdfa)
其中的
指两两不相交的并集。这样的划分方式下,不会有两个集合有交集。反设有两个集合
和
有交集:
![{\displaystyle r_{i}+kb=r_{j}+lb}](https://wikimedia.org/api/rest_v1/media/math/render/svg/e5260343fd6cf38f6a56cc60efb9e04a826b6401)
那么
![{\displaystyle r_{i}-r_{j}=(l-k)b}](https://wikimedia.org/api/rest_v1/media/math/render/svg/1f38fbb2796a59627b51681133683c953f693046)
这说明有两个元素的差是
的倍数。矛盾。另一方面,任何一个整数都必然属于某个
。设有整数
,那么存在整数
使得
,也就是说存在
里的一个数
,使得
同样地,对
里的每一个数
,也各自存在
的一个数
和一个整数
,使得
由于有
个属于集合
的整数,根据抽屉原理,必然有两个整数相同。而由前所证,不可能有
的情况,所以只能是存在某个
使得
,所以:
![{\displaystyle s=q_{s}b+t_{s}=q_{s}b+t_{i}=q_{s}b+r_{i}-q_{i}b}](https://wikimedia.org/api/rest_v1/media/math/render/svg/13201bbb88239c6e66e388556f5d0a36d99a5266)
![{\displaystyle s=r_{i}+(q_{s}-q_{i})b\in R_{q_{s}-q_{i}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/e2367d6943352d894cb6522fd818d1830f7fc247)
因此,任何一个整数都唯一地属于某个
。而对应的这个整数
就是带余除法唯一确定的商。[2]:18-22
计算
计算带余除法和计算除法的手段基本相同。手工计算时常常使用长除法,与除法不同之处是到个位即停止,剩余的即是余数。计算机运算中使用的带余除法一般耗费的时间比相同位数的乘法更久,所以编程时为了减少机器运算量,常常会尽力避免除法运算。一般的编程语言和数学、统计软件中,带余除法运算符(指令)和取模运算符(指令)可能是分开的,也可能是合并的。如在进行带余除法时尽管默认返回的是商,但实际上余数也储存在运算结果中。除数是2的幂次的时候,可以使用右移的位移运算代替带余除法。这是因为计算机储存数据使用的是二进制,取一个长度为
的二进制数的前
位,实际上就是它除以2的
次幂後的商,而後
位则是其余数。
算法
原始算法
原始的带余除法算法可以视为是重复使用减法的过程。设要计算
除以
,则在
里面不断地扣除
,直到不能继续扣除(满足余数范围)为止。以
、
都是正整数,余数范围为
的除法为例,伪代码如下:
function Division(a, b)
q ← 0; r ← a;
while r >= b do
r ← r - b;
q ← q + 1;
end while
return q, r;
这样的算法复杂度是
的级别。[3]
使用二分法
更为优化的算法是使用二进制以及二分法的结合。算法大致分为两个部分:首先用不断倍增的方式找出一个
所属的区间,然后用二分法不断收窄区间,直到将
限制在一个长度为
的区间为止。举例来说,要计算237除以9,可以首先列出如下表格:
0
|
1
|
2
|
3
|
4
|
5
|
1
|
2
|
4
|
8
|
16
|
32
|
9
|
18
|
36
|
72
|
144
|
288
|
也就是从小到大逐个列出2的幂次与9的乘积,直到超过237为止。其中,24 × 9 = 144 是小于等于237的最大数,之後的288就比237更大了。接下来反过来利用2的幂次与9的乘积来计算237除以9。过程如下:
- 设
,
;
- 237介于144与288之间,而144和288的平均数是216,比237小,令
,
;
- 216和288的平均数是252,比237大,令
,
;
- 216和252的平均数是234,比237小,令
,
;
- 234和252的平均数是243,比237大,令
,
;
- 最后得到
的值为26,这就是237除以9的商,237减去234剩余的3就是余数。伪代码如下:
function QuickDivision(a, b)
counter ← 0; power ← 1; mid ← 0; appr ← 0;
//-{zh-hans:找到2的幂次与除数b的乘积中比被除数a大的最小数对应的幂次;zh-hant:找到2的冪次與除數b的乘積中比被除數a大的最小數對應的冪次}-
while power * b <= a do
counter ← counter + 1;
power ← power * 2 ;
end while
p ← power; q ← power / 2;
//p和q乘以b以後分别是a的上界和下界,以下用二分法不断收窄上下界,直到上下界之差等于b(即p与q之差等于1)为止
for k from 1 to counter - 1 do
//计算上下界的平均值
comp ← (p + q) / 2;
mid ← comp * b;
//如果平均值小于等于a,则调高下界,同时记录平均值,否则调低上界
if mid <= a then
appr ← mid;
q ← comp;
else
p ← comp;
end if
end for
//结束后q乘以b的积就是小于等于a的b的倍数中最大的,这说明q就是商;appr是最後一个小于等于a的平均值,所以它和a的差就是余数
r ← a - appr;
return q, r;
以上的算法的复杂度在
级别,当
较大时,远远比原始的算法快捷。[3]
推广
多项式的带余除法
以域
为系数的多项式构成的多项式整环
中也可以定义带余除法。设有
、
两个多项式,其中
不是零多项式。则存在由
和
唯一确定的多项式
和
,使得:
![{\displaystyle A=BQ+R}](https://wikimedia.org/api/rest_v1/media/math/render/svg/2b37f420a7b68179904a3efce197e58cfb6465cd)
并且多项式
是零多项式或者它的次数严格小于
的次数,称为多项式带余除法的余元。[4]:10
欧几里德整环
普通的整数或实数之间的带余除法可以良好定义。在更广泛的代数结构中,能够定义带余除法的代数结构被称为欧几里德整环。定义如下:
- 设有整环
和从
到自然数的映射
,使得:
- 若
而
,则存在
使得
,而且要么有
,或者
。
- 则称
为欧几里德整环。[1]:141
欧几里德整环中,使用一个额外的函数来比较两个元素之间的“大小”关系,从而能够定义带余除法。这个函数也称为范数。欧几里德整环必然是主理想整环因而也必然是唯一分解整环。[1]:141[4]:16-17
参见
参考来源