带余除法
带余除法,也称为欧几里德除法(英語:)是数学中的一种基本算术计算方式。给定一个被除数和一个除数,带余除法给出一个整数和一个介于一定范围的余数,使得下面等式成立:
一般所称“欧几里德除法”,限定余数的范围在0与之间。还有叫做“居中除法”的变体,限定余数在与之间,这种余数称为“居中余数”。这样的限定都是为了使得满足等式的有且仅有一个。这时候的称为带余除法的商。带余除法一般表示为:
表达为:“除以等于,余”。最常见的带余除法是整数与整数的带余除法(被除数a和除数b都是整数),但实数与整数乃至实数与实数的带余除法也有应用。对一般的抽象代数系统,能够进行带余除法的都是具有欧几里德性质的系统。如果余数为零,则称整除。一般约定除数不能为0。
带余除法的计算有长久的历史,有各种计算工具和计算方法。最常用的是长除法(竖式除法)。带余除法在数论中有不少用途,比如说辗转相除法的基本步骤就是带余除法。
例子
以下是整数带余除法的例子:依照公历,一年中的四月份有30天。每星期有7天,从四月的第一天开始,可以数出有四个星期,此外还有2天。如果要数出5个星期,则还差了5天。带余除法表示,就是:
里面的30是被除数,7是除数,4是带余除法得到的商,2是带余除法得到的余数。日常生活中说:“四月份有四个多星期”,是带余除法的结果。
另一个例子是分配问题。假设有30个苹果要分给7个人,每人分的要一样多,那么可以使用带余除法:
这说明每人可以分到4个,还剩余2个。如果每人分5个,则是不够的。每人如果只分3个,则还剩余9个,可以继续分。带余除法说明了在人人分到的要一样多的条件下,每人可以分到的最多苹果数目。
不同的带余除法
最基本的带余除法是整数与整数的带余除法,这时商和余数都是整数。实数与整数的带余除法,或实数与实数的带余除法,余数是实数,但不一定是整数。比如说讨论使用正弦函数构造的数列时,就需要使用除数为的带余除法,来讨论每一项具体的取值。
基本定理
带余除法限定了余数的范围,使得商唯一存在。整数与整数的带余除法中,余数的范围通常是这样的个元素的集合。被除数为实数的带余除法中,常常会使用介于0和除数之间(大于等于0,严格小于)的半开闭区间作为余数的范围;另一种常见的范围是大于等于,严格小于。带余除法的基本定理说明:整数与整数的带余除法中,只要余数的范围是个整数,并且任何两个数之差都不是b的倍数,那么带余除法的商唯一存在;被除数为实数的除法中,只要余数的范围是一个如同长度为的半开半闭区间,那么带余除法的商唯一存在。[1]:25
最常见的带余除法中用到的是整数除以整数的一个版本:
对任何给定的整数和非零整数,都存在唯一的整数以及属于集合的整数,使得
计算
计算带余除法和计算除法的手段基本相同。手工计算时常常使用长除法,与除法不同之处是到个位即停止,剩余的即是余数。计算机运算中使用的带余除法一般耗费的时间比相同位数的乘法更久,所以编程时为了减少机器运算量,常常会尽力避免除法运算。一般的编程语言和数学、统计软件中,带余除法运算符(指令)和取模运算符(指令)可能是分开的,也可能是合并的。如在进行带余除法时尽管默认返回的是商,但实际上余数也储存在运算结果中。除数是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]
推广
参考来源
- 胡冠章, 王殿军. . 北京: 清华大学出版社. 2006. ISBN 9787302125662.
- David M. Burton. . McGraw-Hill. 2010. ISBN 9780073383149 (英语).
- Christian Blanchet. (PDF). Groupes et arithmétique, chapitre 1. Université Paris 7. [2013-11-18]. (原始内容存档 (PDF)于2011-02-06) (法语).
- 张贤科, 许甫华. . 北京: 清华大学出版社. 2004. ISBN 9787302082279.