雨霖霖i
1 中国古代数学的发展 在古代世界四大文明中,中国数学持续繁荣时期最为长久。从公元前后至公元14世纪,中国古典数学先后经历了三次发展高潮,即两汉时期、魏晋南北朝时期和宋元时期,并在宋元时期达到顶峰。 与以证明定理为中心的希腊古典数学不同,中国古代数学是以创造算法特别是各种解方程的算法为主线。从线性方程组到高次多项式方程,乃至不定方程,中国古代数学家创造了一系列先进的算法(中国数学家称之为“术”),他们用这些算法去求解相应类型的代数方程,从而解决导致这些方程的各种各样的科学和实际问题。特别是,几何问题也归结为代数方程,然后用程式化的算法来求解。因此,中国古代数学具有明显的算法化、机械化的特征。以下择要举例说明中国古代数学发展的这种特征。 1.1 线性方程组与“方程术” 中国古代最重要的数学经典《九章算术》(约公元前2世纪)卷8的“方程术”,是解线性方程组的算法。以该卷第1题为例,用现代符号表述,该问题相当于解一个三元一次方程组: 3x+2y+z=39 2x+3y+z=34 x+2y+3z=26 《九章》没有表示未知数的符号,而是用算筹将x�y�z的系数和常数项排列成一个(长)方阵: 1 2 3 2 3 2 3 1 1 26 34 39 “方程术”的关键算法叫“遍乘直除”,在本例中演算程序如下:用右行(x)的系数(3)“遍乘”中行和左行各数,然后从所得结果按行分别“直除”右行,即连续减去右行对应各数,就将中行与左行的系数化为0。反复执行这种“遍乘直除”算法,就可以解出方程。很清楚,《九章算术》方程术的“遍乘直除” 算法,实质上就是我们今天所使用的解线性方程组的消元法,以往西方文献中称之为“高斯消去法”,但近年开始改变称谓,如法国科学院院士、原苏黎世大学数学系主任P.Gabriel教授在他撰写的教科书[4]中就称解线性方程组的消元法为“张苍法”,张苍相传是《九章算术》的作者之一。 1.2 高次多项式方程与“正负开方术” 《九章算术》卷4中有“开方术”和“开立方术”。《九章算术》中的这些算法后来逐步推广到开更高次方的情形,并且在宋元时代发展为一般高次多项式方程的数值求解。秦九韶是这方面的集大成者,他在《数书九章》(1247年)一书中给出了高次多项式方程数值解的完整算法,即他所称的“正负开方术”。 用现代符号表达,秦九韶“正负开方术”的思路如下:对任意给定的方程 f(x)=a0xn+a1xn-1+……+an-2x2+an-1x+an=0 (1) 其中a0≠0,an<0,要求(1)式的一个正根。秦九韶先估计根的最高位数字,连同其位数一起称为“首商”,记作c,则根x=c+h,代入(1)得 f(c+h)=a0(c+h)n+a1(c+h)n-1+……+an-1(c+h)+an=0 按h的幂次合并同类项即得到关于h的方程: f(h)=a0hn+a1hn-1+……+an-1h+an=0 (2) 于是又可估计满足新方程(2)的根的最高位数字。如此进行下去,若得到某个新方程的常数项为0,则求得的根是有理数;否则上述过程可继续下去,按所需精度求得根的近似值。 如果从原方程(1)的系数a0,a1,…,an及估值c求出新方程(2)的系数a0,a1,…,an的算法是需要反复迭代使用的,秦九韶给出了一个规格化的程序,我们可称之为“秦九韶程序”, 他在《数书九章》中用这一算法去解决各种可以归结为代数方程的实际问题,其中涉及的方程最高次数达到10次,秦九韶解这些问题的算法整齐划一,步骤分明,堪称是中国古代数学算法化、机械化的典范。 1.3 多元高次方程组与“四元术” 绝不是所有的问题都可以归结为线性方程组或一个未知量的多项式方程来求解。实际上,可以说更大量的实际问题如果能化为代数方程求解的话,出现的将是含有多个未知量的高次方程组。 多元高次方程组的求解即使在今天也绝非易事。历史上最早对多元高次方程组作出系统处理的是中国元代数学家朱世杰。朱世杰的《四元玉鉴》(1303年)一书中涉及的高次方程达到了4个未知数。朱世杰用“四元术”来解这些方程。“四元术”首先是以“天”、“地”、“人”、“物”来表示不同的未知数,同时建立起方程式,然后用顺序消元的一般方法解出方程。朱世杰在《四元玉鉴》中创造了多种消元程序。 通过《四元玉鉴》中的具体例子可以清晰地了解朱世杰“四元术”的特征。值得注意的是,这些例子中相当一部分是由几何问题导出的。这种将几何问题转化为代数方程并用某种统一的算法求解的例子,在宋元数学著作中比比皆是,充分反映了中国古代几何代数化和机械化的倾向。 1.4 一次同余方程组与“中国剩余定理” 中国古代数学家出于历法计算的需要,很早就开始研究形如: X≡Ri (mod ai) i=1,2,...,n (1) (其中ai 是两两互素的整数)的一次同余方程组求解问题。公元4世纪的《孙子算经》中已有相当于求解下列一次同余组的著名的“孙子问题”: X≡2(mod3) ≡3(mod5) ≡2(mod7) 《孙子算经》作者给出的解法,引导了宋代秦九韶求解一次同余组的一般算法——“大衍求一术”。现代文献中通常把这种一般算法称为“中国剩余定理”。 1.5 插值法与“招差术” 插值算法在微积分的酝酿过程中扮演了重要角色。在中国,早从东汉时期起,学者们就惯用插值法来推算日月五星的运动。起初是简单的一次内插法,隋唐时期出现二次插值法(如一行《大衍历》,727年)。由于天体运动的加速度也不均匀,二次插值仍不够精密。随着历法的进步,到了宋元时代,便产生了三次内插法(郭守敬《授时历》,1280年)。在此基础上,数学家朱世杰更创造出一般高次内插公式,即他所说的“招差术”。 朱世杰的公式相当于 f(n)=n△+ n(n�1)△2+ n(n�1)(n�2)△3 + n(n�1)(n�2)(n�3)△4+…… 这是一项很突出的成就。 这里不可能一一列举中国古代数学家的所有算法,但仅从以上介绍不难看到,古代与中世纪中国数学家创造的算法,有许多即使按现代标准衡量也达到了很高的水平。这些算法所表达的数学真理,有的在欧洲直到18世纪以后依赖近代数学工具才重新获得(如前面提到的高次代数方程数值求解的秦九韶程序,与1819年英国数学家W. 霍纳重新导出的“霍纳算法”基本一致;多元高次方程组的系统研究在欧洲也要到18世纪末才开始在E. 别朱等人的著作中出现;解一次同余组的剩余定理则由欧拉与高斯分别独立重新获得;至于朱世杰的高次内插公式,实质上已与现在通用的牛顿-格列高里公式相一致)。这些算法的结构,其复杂程度也是惊人的。如对秦九韶“大衍求一术”和“正负开方术”的分析表明,这些算法的计算程序,包含了现代计算机语言中构造非平易算法的基本要素与基本结构。这类复杂的算法,很难再仅仅被看作是简单的经验法则了,而是高度的概括思维能力的产物,这种能力与欧几里得几何的演绎思维风格截然不同,但却在数学的发展中起着完全可与之相媲美的作用。事实上,古代中国算法的繁荣,同时也孕育了一系列极其重要的概念,显示了算法化思维在数学进化中的创造意义和动力功能。以下亦举几例。 1.6 负数的引进 《九章算术》“方程术”的消元程序,在方程系数相减时会出现较小数减较大数的情况,正是在这里,《九章算术》的作者们引进了负数,并给出了正、负数的加减运算法则,即“正负术”。 对负数的认识是人类数系扩充的重大步骤。公元7世纪印度数学家也开始使用负数,但负数的认识在欧洲却进展缓慢,甚至到16世纪,韦达的著作还回避负数。 1.7 无理数的发现 中国古代数学家在开方运算中接触到了无理数。《九章算术》开方术中指出了存在有开不尽的情形:“若开方不尽者,为不可开”,《九章算术》的作者们给这种不尽根数起了一个专门名词——“面”。“面”,就是无理数。与古希腊毕达哥拉斯学派发现正方形的对角线不是有理数时惊慌失措的表现相比,中国古代数学家却是相对自然地接受了那些“开不尽”的无理数,这也许应归功于他们早就习惯使用的十进位制,这种十进位制使他们能够有效地计算“不尽根数”的近似值。为《九章算术》作注的三国时代数学家刘徽就在“开方术”注中明确提出了用十进制小数任意逼近不尽根数的方法,他称之为“求微数法”,并指出在开方过程中,“其一退以十为步,其再退以百为步,退之弥下,其分弥细,则……虽有所弃之数,不足言之也”。 十进位值记数制是对人类文明不可磨灭的贡献。法国大数学家拉普拉斯曾盛赞十进位值制的发明,认为它“使得我们的算术系统在所有有用的创造中成为第一流的”。中国古代数学家正是在严格遵循十进位制的筹算系统基础上,建立起了富有算法化特色的东方数学大厦。 1.8 贾宪三角或杨辉三角 从前面关于高次方程数值求解算法(秦九韶程序)的介绍我们可以看到,中国古代开方术是以�c+hn的二项展开为基础的,这就引导了二项系数表的发现。南宋数学家杨辉著《详解九章算法》(1261年)中,载有一张所谓“开方作法本源图”,实际就是一张二项系数表。这张图摘自公元1050年左右北宋数学家贾宪的一部著作。“开方作法本源图”现在就叫“贾宪三角”或“杨辉三角”。二项系数表在西方则叫“帕斯卡三角”�1654年。 1.9 走向符号代数 解方程的数学活动,必然引起人们对方程表达形式的思考。在这方面,以解方程擅长的中国古代数学家们很自然也是走在了前列。在宋元时期的数学著作中,已出现了用特定的汉字作为未知数符号并进而建立方程的系统努力。这就是以李冶为代表的“天元术”和以朱世杰为代表的“四元术”。所谓“天元术”,首先是“立天元一为某某”,这相当于“设为某某”,“天元一”就表示未知数,然后在筹算盘上布列“天元式”,即一元方程式。该方法被推广到多个未知数情形,就是前面提到的朱世杰的“四元术”。因此,用天元术和四元术列方程的方法,与现代代数中的列方程法已相类似。 符号化是近世代数的标志之一。中国宋元数学家在这方面迈出了重要一步,“天元术”和“四元术”,是以创造算法特别是解方程的算法为主线的中国古代数学的一个高峰�。 2 中国古代数学对世界数学发展的贡献 数学的发展包括了两大主要活动:证明定理和创造算法。定理证明是希腊人首倡,后构成数学发展中演绎倾向的脊梁;算法创造昌盛于古代和中世纪的中国、印度,形成了数学发展中强烈的算法倾向。统观数学的历史将会发现,数学的发展并非总是演绎倾向独占鳌头。在数学史上,算法倾向与演绎倾向总是交替地取得主导地位。古代巴比伦和埃及式的原始算法时期,被希腊式的演绎几何所接替,而在中世纪,希腊数学衰落下去,算法倾向在中国、印度等东方国度繁荣起来;东方数学在文艺复兴前夕通过阿拉伯传播到欧洲,对近代数学兴起产生了深刻影响。事实上,作为近代数学诞生标志的解析几何与微积分,从思想方法的渊源看都不能说是演绎倾向而是算法倾向的产物。 从微积分的历史可以知道,微积分的产生是寻找解决一系列实际问题的普遍算法的结果�6�。这些问题包括:决定物体的瞬时速度、求极大值与极小值、求曲线的切线、求物体的重心及引力、面积与体积计算等。从16世纪中开始的100多年间,许多大数学家都致力于获得解决这些问题的特殊算法。牛顿与莱布尼兹的功绩是在于将这些特殊的算法统一成两类基本运算——微分与积分,并进一步指出了它们的互逆关系。无论是牛顿的先驱者还是牛顿本人,他们所使用的算法都是不严格的,都没有完整的演绎推导。牛顿的流数术在逻辑上的瑕疵更是众所周知。对当时的学者来说,首要的是找到行之有效的算法,而不是算法的证明。这种倾向一直延续到18世纪。18世纪的数学家也往往不管微积分基础的困难而大胆前进。如泰勒公式,欧拉、伯努利甚至19世纪初傅里叶所发现的三角展开等,都是在很长时期内缺乏严格的证明。正如冯·诺伊曼指出的那样:没有一个数学家会把这一时期的发展看作是异端邪道;这个时期产生的数学成果被公认为第一流的。并且反过来,如果当时的数学家一定要在有了严密的演绎证明之后才承认新算法的合理性,那就不会有今天的微积分和整个分析大厦了。 现在再来看一看更早的解析几何的诞生。通常认为,笛卡儿发明解析几何的基本思想,是用代数方法来解几何问题。这同欧氏演绎方法已经大相径庭了。而事实上如果我们去阅读笛卡儿的原著,就会发现贯穿于其中的彻底的算法精神。《几何学》开宗明义就宣称:“我将毫不犹豫地在几何学中引进算术的术语,以便使自己变得更加聪明”。众所周知,笛卡儿的《几何学》是他的哲学著作《方法论》的附录。笛卡儿在他另一部生前未正式发表的哲学著作《指导思维的法则》(简称《法则》)中曾强烈批判了传统的主要是希腊的研究方法,认为古希腊人的演绎推理只能用来证明已经知道的事物,“却不能帮助我们发现未知的事情”。因此他提出“需要一种发现真理的方法”,并称之为“通用数学”(mathesis universakis)。笛卡儿在《法则》中描述了这种通用数学的蓝图,他提出的大胆计划,概而言之就是要将一切科学问题转化为求解代数方程的数学问题: 任何问题→数学问题→代数问题→方程求解而笛卡儿的《几何学》,正是他上述方案的一个具体实施和示范,解析几何在整个方案中扮演着重要的工具作用,它将一切几何问题化为代数问题,这些代数问题则可以用一种简单的、几乎自动的或者毋宁说是机械的方法去解决。这与上面介绍的古代中国数学家解决问题的路线可以说是一脉相承。 因此我们完全有理由说,在从文艺复兴到17世纪近代数学兴起的大潮中,回响着东方数学特别是中国数学的韵律。整个17—18世纪应该看成是寻求无穷小算法的英雄年代,尽管这一时期的无穷小算法与中世纪算法相比有质的飞跃。而从19世纪特别是70年代直到20世纪中,演绎倾向又重新在比希腊几何高得多的水准上占据了优势。因此,数学的发展呈现出算法创造与演绎证明两大主流交替繁荣、螺旋式上升过程: 演绎传统——定理证明活动 算法传统——算法创造活动 中国古代数学家对算法传统的形成与发展做出了毋容置疑的巨大贡献。 我们强调中国古代数学的算法传统,并不意味中国古代数学中没有演绎倾向。事实上,在魏晋南北朝时期一些数学家的工作中,已出现具有相当深度的论证思想。如赵爽勾股定理证明、刘徽“阳马”�一种长方锥体体积证明、祖冲之父子对球体积公式的推导等等,均可与古希腊数学家相应的工作媲美。赵爽勾股定理证明示意图“弦图”原型,已被采用作2002年国际数学家大会会标。令人迷惑的是,这种论证倾向随着南北朝的结束,可以说是戛然而止。囿于篇幅和本文重点,对这方面的内容这里不能详述,有兴趣的读者可参阅参考文献�3�。 3 古为今用,创新发展 到了20世纪,至少从中叶开始,电子计算机的出现对数学的发展带来了深远影响,并孕育出孤立子理论、混沌动力学、四色定理证明等一系列令人瞩目的成就。借助计算机及有效的算法猜测发现新事实、归纳证明新定理乃至进行更一般的自动推理……,这一切可以说已揭开了数学史上一个新的算法繁荣时代的伟大序幕。科学界敏锐的有识之士纷纷预见到数学发展的这一趋势。在我国,早在上世纪50年代,华罗庚教授就亲自领导建立了计算机研制组,为我国计算机科学和数学的发展奠定了基础。吴文俊教授更是从70年代中开始,毅然由原先从事的拓扑学领域转向定理机器证明的研究,并开创了现代数学的崭新领域——数学机械化。被国际上誉为“吴方法”的数学机械化方法已使中国在数学机械化领域处于国际领先地位,而正如吴文俊教授本人所说:“几何定理证明的机械化问题,从思维到方法,至少在宋元时代就有蛛丝马迹可寻,”他的工作“主要是受中国古代数学的启发”。“吴方法”,是中国古代数学算法化、机械化精髓的发扬光大。 计算机影响下算法倾向的增长,自然也引起一些外国学者对中国古代数学中算法传统的兴趣。早在上世纪70年代初,著名的计算机科学家D.E.Knuth就呼吁人们关注古代中国和印度的算法�5�。多年来这方面的研究取得了一定进展,但总的来说还亟待加强。众所周知,中国古代文化包括数学是通过著名的丝绸之路向西方传播的,而阿拉伯地区是这种文化传播的重要中转站。现存有些阿拉伯数学与天文著作中包含有一定的中国数学与天文学知识,如著名的阿尔·卡西《算术之钥》一书中有相当数量的数学问题显示出直接或间接的中国来源,而根据阿尔·卡西本人记述,他所工作的天文台中就有不少来自中国的学者。 然而长期以来由于“西方中心论”特别是“希腊中心论”的影响以及语言文字方面的障碍,有关资料还远远没有得到发掘。正是为了充分揭示东方数学与欧洲数学复兴的关系,吴文俊教授特意从他荣获的国家最高科学奖中拨出专款成立了“吴文俊数学与天文丝路基金”,鼓励支持年轻学者深入开展这方面的研究,这是具有深远意义之举。 研究科学的历史,其重要意义之一就是从历史的发展中获得借鉴和汲取教益,促进现实的科学研究,通俗地说就是“古为今用”。吴文俊对此有精辟的论述,他说:“假如你对数学的历史发展,对一个领域的发生和发展,对一个理论的兴旺和衰落,对一个概念的来龙去脉,对一种重要思想的产生和影响等这许多历史因素都弄清了,我想,对数学就会了解得更多,对数学的现状就会知道得更清楚、更深刻,还可以对数学的未来起一种指导作用,也就是说,可以知道数学究竟应该按怎样的方向发展可以收到最大的效益”。数学机械化理论的创立,正是这种古为今用原则的硕果。我国科学技术的伟大复兴,呼唤着更多这样既有浓郁的中国特色、又有鲜明时代气息的创新。
天使禁猎区0
从算法教学管窥中国古代数学史俞 昕( 浙江湖州市第二中学 313000) 关于算法的涵义, 人们有着不同的界定. 普通高中数学课程标准( 实验) 在学生算法目标达成度上,重在算法思想的理解与应用,界定现代算法的意义就是解决某一类问题的办法. 确切地说,就是对于某一类特定的问题,算法给出了解决问题的一系列(有穷) 操作, 即每一操作都有它的确定性的意义( 使计算机能够按照它的指令工作) ,并在有限时间( 有穷步骤)内计算出结果.普通高中数学课程标准( 实验) 对! 算法部分∀进行说明时,突出强调! 需要特别指出的是, 中国古代数学中蕴涵了丰富的算法思想∀. 吴文俊先生曾经说过! 我们崇拜中国传统数学,决非泥古迷古、 为古而古. 复古是没有出路的. 我们的目的不仅是要显示中国古算的真实面貌, 也不仅是为了破除对西算的盲从,端正对中算的认识,我们主要的也是真正的目的, 是在于古为今用. ∀算法教学中蕴涵着丰富的数学史教育价值, 作为新时代的高中数学教师是有必要了解这一点的.1 中国古代数学的特点古代数学思想分为两大体系, 一个是以欧几里得的几何原本 为代表的西方数学思想体系,这个体系以公理化的思想、 抽象化的方法、 封闭的演绎体系为特色. 另一个则是以我国的九章算术 为代表的东方数学思想体系,这个体系以算法化的思想、 构造性的方法、 开放的归纳体系为特色.我国传统数学在从问题出发,以解决问题为主旨的发展过程中, 建立了以构造性与机械化为其特色的算法体系, 这与西方数学以欧几里得几何原本 为代表的所谓公理化演绎体系正好遥遥相对.中国古代数学中的! 术∀相当于现代数学术语中的! 公式∀,两者虽有相同点(都可以用来解决一类有关问题) , 其差异也非常之大. 主要表现在,! 公式∀只提供了几个有关的量之间的关系, 指明通过哪些运算可由已知量求出未知量,但并没有列出具体的运算程序,一般地,认为这种程序是已知的了. 但! 术∀则由怎样运算的详细程序构成的,可以说它是为完成公式所指出的各种运算的具体程序,即把! 公式∀展开为使用某种计算工具的具体操作步骤. 从这点看, ! 术∀正是现代意义上的算法, 是用一套! 程序语言∀所描写的程序化算法,可以照搬到现代计算机上去. 我国古代数学包括了今天初等数学中的算术、 代数、 集合和三角等多方面的内容.由于受实用价值观的影响, 中国传统数学的研究遵循着一种算法化思想,这种思想从九章算术 开始一直是中国古代数学著作大都沿袭的模式:实际问题# # # 归类# # # 筹式模型化# # # 程序化算法即将社会生产生活中的问题,先编成应用问题,按问题性质分类, 然后概括地近似地表述出一种数学模型, 借助于算筹, 得到这一类问题的一般解法. 把算法综合起来, 得到一般原理, 分别隶属于各章,人们按照书中的方法、 原理和实例来解决各种实际问题. 可以说,中国传统数学以确定算法为基本内容,又以创造和改进算法为其发展的方向.受九章算术 的影响,在之后的几个世纪,一些数学家的著作都以算法为主要特点,包括王孝通的辑古算经 、 贾宪的黄帝九章算法细草 、 刘益的议古根源 、 秦九韶的数书九章 、 李冶的测圆海镜 和益古演段 、 杨辉的详解九章算法 、 日用算法 和杨辉算法 , 这些著作中包括了增乘开方术、 贾宪三角、 高次方程数值解法、 内插法、 一次同余式组解法等一些著名的算法,进一步发展了中国古代数学算法化的特点,使得算法的特点得到了进一步的强化和发展.1 1 中国古代数学的算法化思想算法化的思想是中国古代数学的重要特点,并贯穿于中国古算整个发展过程之中.即使是与24 数学通报 2010 年 第49 卷 第2 期图形有关的几何问题也不例外,中算家们将几何方法与算法有机地结合起来,实现了几何问题的算法化.这样,从问题出发建立程序化的算法一直是古代中国数学研究的传统,也是中算家们努力的方向.这种算法化的思想着重构造实践,更强调! 经验∀、 ! 发现∀和构造性思维方式下从无到有的发明,对今天的算法教学与研究具有重要的启迪作用.中国古代数学算法化的思想具体表现如下:第一步,把实际中提出的各种问题转化为数学模型;第二步,把各种数学模型转化为代数方程; 第三步,把代数方程转化为一种程序化的算法; 第四步,设计( 并逐步改进)、 归纳、 推导(寓推理于算法之中)出各种算法; 第五步,通过计算回溯逐步达到解决原来的问题.1 2 中国古代数学的构造性方法所谓构造性方法是解决数学问题的一种方法,是创造性思维方式直接作用的结果.按照现代直觉主义者,特别是构造主义者的观点,对于一个数学对象,只有当它可以通过有限次的操作而获得,并且在每步操作之后都能有效地确定下一步所需要采取的操作, 才能说它是存在的.按照这种思维方式,可以使概念和方法按固定的方式在有限步骤内进行定义或得以实施,或给出一个行之有效的过程使之在有限步骤内将结果确定地构造出来.换言之,就是能用有限的手段刻画数学对象并针对问题提出具体的解法.中国古代数学的算法化思想与构造性的方法紧密相连.由于古代中算家所关心的大多是较为实用的问题,他们在解决问题时首先考虑是如何得到可以直接应用的、 可以方便操作的解,而不会满足于仅仅知道解在理论上的存在性. 因为这种纯粹的理论解对于受实用价值观影响的中算家来说是没有多大意义的.从而我们推断,构造性方法的产生是算法化思想直接作用的结果.从我国许多经典算书中可以发现, 数学构造性方法在算法中有许多精彩的体现. 例如就! 方程∀的筹算图阵及其程序设计而言,首先, ! 群物总杂,各列有数,总言其实∀,这是对每行中未知数的系数和常数项的安排,其次, ! 令每行为率,二物者再程,三物者三程,皆如物数程之∀,这是对诸行关系的安排, ! 并列为行∀又说明了什么叫! 方程∀. 这为中国古代数学的构造性方法提供了一个具有说服力的样板.由于构造性的方法特别强调运算的可操作程度, 所以构造出的! 术∀可以通过一系列有限的运算求出解来, 具有一般性.时至今日我国古算家所设计的许多算法几乎都可以整套照搬到现代的电子计算机上实现.这也是我国古算在算法上长期居于领先地位的一个重要原因.2 中国古代数学中的优秀算法案例2. 1 中国古代的代数学代数学是中国传统数学中一个值得骄傲和自豪的领域.中小学数学中的算术、 代数内容, 从记数以至解联立的线性方程组, 实质上都是中国古代数学家的发明创造.结合新课程的算法教学,笔者选取我国古代著名算法进行分析.2. 1. 1 求最大公约数的算法(更相减损术)中国古代数学中,未曾出现素数、 因数分解等概念,但是发明了求两整数的最大公约数的方法# # # 更相减损术: ! 可半者半之,不可半者,副置分母子之数, 以少减多, 更相减损,求其等也.以等数约之. ∀事实上此术中包含了三个步骤:第一步, ! 可半者半之∀, 即进行观察, 若分子、分母都是偶数,可先取其半;第二步, ! 不可半者, 副置分母、 子之数, 以少减多,更相减损,求其等也∀;第三步, ! 以等数约之∀.其中第二步! 以少减多, 更相减损∀是关键,又是典型的机械化程序.在中国古代数学中, 将最大公约数称作! 等∀.由于! 更相减损∀过程终可以在有限步骤内实现, 所以它是一种构造性的方法.若用现代语言翻译即为:第一步,任意给定两个正整数, 判断它们是否都是偶数. 若是,用2 约减,若不是, 执行第二步. 第二步, 以较大的数减去较小的数, 接着把所得的差与较小的数比较, 并以大数减小数.继续这个操作, 直到所得的数相等为止, 则这个数( 等数)或这个数与约简的数的乘积就是所求的最大公约数.下面运用 QBA SIC 语言来编写相应的程序( 见程序1) .25 2010 年 第49 卷 第2 期 数学通报程序 1INPUT! m, n= ∀ ; m, nIF m< n T HEN a= m m= n n= aEND IFk= 0WHILE m MOD 2= 0 AND n MOD2= 0 m= m/ 2 n= n/ 2 k= k+ 1WENDd= m- nWHILE d< > n IF d> n TH EN m= d ELSE m= n n= d END IF d = m- nWENDd= 2 ∃ k * dPRINT dEND程序 2INPUT A, BWHILE A < > B IF A> B T H EN A = A- B ELSE B= B - A END IFWENDPRINT BEND程序 3INPUT ! M, N (M> N )∀ ; M, NDOR= M- N IF R> N TH EN M= R ELSE M= N N= R END IFLOOP UNTIL R= 0PRINT MEND程序 4INPUT ! n= ∀ ; nINPUT! an= ∀; aINPUT! x= ∀ ; xv= ai= n- 1WH ILE i> = 0 PRINT ! i= ∀; i INPUT! ai= ∀ ; a v= v * x+ a i= i- 1WENDPRINT vEND程序 2和 3 是两个简化的参考程序, 是从不同的角度来实现更相减损的过程.! 更相减损术∀提供了一种求两数最大公约数的算法, 这是九章算术 的一个重要成就, 与古希腊欧几里得的几何原本 中用来求最大公约数的! 欧几里得算法∀, 即辗转相除法, 有异曲同工之妙. 欧几里得在几何原本 中针对这个问题引入了许多概念, 给出了冗长的逻辑证明. 尽管如此,他还是暗用了一条未加说明的公理, 即如果 a, b都被c 整除, 则a- mb也能被c 整除.中国古算采用的! 更相减损∀方法,实际上也暗用了一条未加说明的公理, 即若 a- b 可以被c 整除,则 a, b 都能被c 整除. 正如刘徽在九章算术注 中! 其所以相减者, 皆等数之重叠∀. 从形式上看! 更相减损术∀比! 辗转相除法∀更复杂, 循环次数要比辗转相除法多, 但对于计算机来说, 作乘除运算要比作加减运算慢得多, 因此更相减损术在计算机上更为好用.26 数学通报 2010 年 第49 卷 第2 期2. 1. 2 求一元 n 次多项式值的算法(秦九韶算法)秦九韶,南宋著名数学家,其学术思想充分体现在数书九章 这一光辉名著中,该著作不仅继承了九章算术 的传统模式, 对中算的固有特点发扬光大,而且完全符合宋元社会的历史背景, 是中世纪世界数学史上的光辉篇章. 书中记载了! 正负开方术∀、 ! 大衍求一术∀等著名算法.在数书九章 卷五第 17 个问题以! 尖田求积∀为例的算法程序中,可以看出秦九韶对于求一元n 次多项式f ( x ) = anxn+ an- 1 xn- 1+ %+ a1x+ a0 的值所提出的算法.秦九韶算法的特点在于通过反复计算n 个一次多项式,逐步得到原多项式的值. 在欧洲, 英国数学家霍纳( Horner ) 在1819 年才创造了类似的方法, 比秦九韶晚了572年.秦九韶算法把求f ( x ) = anxn+ an- 1 xn- 1+ %+ a1x + a0 的 值 转 化 为 求 递 推 公 式v0= anvk= vk- 1x+ an- k k= 1, 2, %, n中 v n 的值. 通过这种转化, 把运算的次数由至多( 1+ n) n2次乘法运算和n 次加法运算,减少为至多 n 次乘法运算和n 次加法运算,大大提高了运算效率.这种算法的QBASIC 语言程序如程序 4 所示.算法步骤是如下的五步: 第一步, 输入多项式次数 n、 最高次项的系数an 和x 的值;第二步,将 v 的值初始化为a v ,将i 的值初始化为n- 1; 第三步, 输入 i次项的系数ai ;第四步, v= v x+ ai , i= i- 1; 第五步,判断i 是否大于或等于 0, 若是, 则返回第三步,否则输出多项式的值v .2. 2 中国古代的几何学中国古代的几何学从田亩丈量等生产生活中的一些实际问题中产生, 并为生产生活服务. 基于传统实用价值观的影响, 中国古代的几何学并没有发展成为像欧氏几何那样严密的公理化演绎体系,所以中国古代几何学在整个数学史上的地位并不突出,但在许多几何问题的处理上也突出了算法化这一特色. 下面以! 割圆术∀为例作简要分析.中国古代数学家刘徽创立! 割圆术∀来求圆的面积及其相关问题. 刘徽! 瓤而裁之∀,即对与圆周合体的正多边形进行无穷小分割,分成无穷多个以正多边形每边为底、 圆心为顶点的小等腰三角形, 这无穷多个小三角形的面积之和就是圆的面积. 这样通过对直线形的无穷小分割, 然后求其极限状态的和的方式证明了圆的面积公式.刘徽的算法! 割之弥细,所失弥少,割之又割, 以至于不可割, 则与圆合体而无所失矣∀体现出程序化的过程, 可以看出圆内接正多边形逐渐逼近圆的变化趋势,并且刘徽依此开创了求圆周率精确近似值的方法, 将这种极限思想用于近似计算.其中包含有迭代过程和子程序,是一种典型的循环算法,充分体现了程序化的特点.中算家的几何学,并不追求逻辑论证的完美,而是着重于实际计算问题的解决, ! 析理以辞, 解体用图∀, 以建立解决问题的一般方法和一般原则. 但另一方面,这种几何学又是以面积、 体积、 勾股相似等为基本概念,以长方形面积算法、 长方形体积算法、 相似勾股形的性质为出发点的, 整个几何理论建立在! 出入相补原理∀等基本原理之上.例如,由勾股定理自然地引起平方根的计算问题,而求平方根和立方根的方法, 其步骤就是以出入相补原理为几何背景逐步索骥而得.这方面内容的介绍, 不仅可以丰富学生的算法知识,而且可以通过揭示蕴藏其中的数学背景和文化内涵, 激发学生学习算法的兴趣,体会算法在人类发展史中的作用.3 中国古代数学算法的教学价值3. 1 培养正确数学观的良好平台中国传统算法尽管与现代算法在具体形式上差别很大,但是重要的是形式后面的认识论发展线索可以为现代算法教学的体系、 教学层次提供依据.它的具体数学知识载体也是现代算法教学的重要源泉. 各种算法的创立就是创造性劳动的产物,即是创造思维的一种! 凝固∀和! 外化∀. 其次, 通过把一部分问题的求解归结为对于现成算法的! 机械应用∀, 这就为人们积极地去从事新的创造性劳动提供了更大的可能性. 从而算法化也就意味着由一个平台向更高点的跳跃.吴文俊先生的研究使中国传统数学的算法重见天日, 开拓了数学机械化的新领域, 吴先生提出! 数学教育的现代化就是机械化∀.他在研究中这样写道: 数学问题的机械化, 就要求在运算和证明过程中, 每前进一步之后,都有一个确定的必须选27 2010 年 第49 卷 第2 期 数学通报择的下一步, 这样沿着一条有规律的, 刻板的道路,一直达到结论.证明机械化的实质在于, 把通常数学证明中所固有的质的困难,转化为计算的量的复杂性.计算的量的复杂性在过去是人力不可能解决的,而计算机的出现解决了这种复杂性.吴先生的理论和实践已经表明,证明和计算是数学的两个方面, 且又是统一的,这在数学教育中具有重要意义.我们应当引导学生了解古人对问题思考的角度,学会站在巨人的肩膀上,比如按照中国古代开方术的思路就可以编造程序在现代计算机上实现开方.培养学生在学习数学知识的同时更多地关心所学知识的社会意义和历史意义,力图在面向未来的同时,通过同传统上的哲学、 历史和社会学的思想结合起来, 形成正确的数学观.算法教学就为此搭建了一个良好的平台, 并且承载丰富的历史底蕴.3. 2 渗透爱国主义教育的最佳契机与西方相比, 中算理论具有高度概括与精练的特征, 中算家经常将其依据的算理蕴涵于演算的步骤之中, 起到! 不言而喻, 不证自明∀的作用,可以认为中国传统数学乃是为建立那些在实际中有直接应用的数学方法而构造的最为简单, 精巧的理论建筑物. 因此, 中算理论可以说是一种! 纲目结构∀:目是组成理论之网的眼孔;纲是联结细目的总绳.以术为目, 以率为纲,即是依算法划分理论单元,而用基本的数量关系把它们连结成一个整体. 纲举目张,只有抓住贯串其中的基本理论与原理, 才能看清算法的来龙去脉.下面是吴文俊先生总结的! 关于算术代数部分发明创造的一张中外对照表∀.从算法教学管窥中国古代数学史中国 外国位值制十进位记 最迟在九章算术 成书时已十分成熟 印度最早在 6 世纪末才出现分数运算 周髀算经 中已有, 在九章算术 成书时已成熟 印度最早在 7 世纪才出现十进位小数 刘徽注中引入, 宋秦九韶 1247年时已通行 西欧 16 世纪时始有之, 印度无开平方、 立方 周髀算经 中已有开平方, 九章算术 中开平、 立方已成熟西方在 4 世纪末始有开平方, 但还无开立方, 印度最早在 7 世纪算术应用 九章算术 中有各种类型的应用问题 印度 7 世纪后的数学书中有某些与中国类似的问题与方法正负数 九章算术 中已成熟 印度最早见于 7 世纪,西欧至 16 世纪始有之联立一次方程组 九章算术 中已成熟 印度 7 世纪后开始有一些特殊类型的方程组, 西方迟至 16 世纪始有之二次方程 九章算术 中已隐含了求数值解法,三国时有一般解求法 印度在 7 世纪后,阿拉伯在 9世纪有一般解求法三次方程 唐初( 公元 7 世纪初) 有列方程法, 求数值解已成熟西欧至 16 世纪有一般解求法, 阿拉伯 10 世纪有几何解高次方程 宋时( 12 # 13 世纪)已有数值解法 西欧至 19 世纪初始有同样方法联立高次方程组与消元法 元时( 14 世纪初) 已有之 西欧甚迟,估计在 19 世纪28 数学通报 2010 年 第49 卷 第2 期3. 3 品位数学美学思想的美妙境界中国古代数学不但具有实用性特征, 还蕴涵着丰富的美学思想. 比如九章算术 中列方程的方式,相当于列出其增广矩阵,其消元过程相当于矩阵变换,而矩阵是数学美学方法中对称最典型的表现形式之一; 九章算术 中用几何方法巧妙地解决了很多代数问题, 这是数形结合的统一: 把数学问题改编成歌诀,以便于掌握和传授,这是文学艺术与数学的统一. 总之, 在算法教学中, 应努力把握和利用自己文化传统中的积极因素进行教学,这对数学教育的发展具有重要的意义.参考文献1 中学数学课程教材研究开发中心. 普通高中课程标准实验教材书(数学) [ M] . 北京: 人民教育出版社, 20072 中华人民共和国教育部. 普通高中数学课程标准(实验) [ M] .北京: 人民教育出版社, 20033 李文林. 数学史概论(第二版) [ M ] . 北京: 高等教育出版社, 20024 王鸿钧, 孙宏安. 中国古代数学思想方法[ M] . 南京: 江苏教育出版社, 19885 张维忠. 数学, 文化与数学课程[ M] . 上海: 上海教育出版社, 19996 吴文俊. 吴文俊论数学机械化[ M ] . 济南: 山东教育出版社, 19957 代钦. 儒家思想与中国传统数学[ M] . 北京: 商务印书馆, 20038 费泰生. 算法及其特征[ J] . 数学通讯, 2004, 79 张奠宙. 算法[ J] . 科学, 2003, 55( 2)10 李建华. 算法及其教育价值[ J ] . 数学教育学报, 2004, 311 李亚玲. 算法及其学习的意义[ J ] . 数学通报, 2004, 2(上接第23 页) 实验教师对课改实验进行探索、 总结、 反思、 调整, 推广比较成熟的经验,同时纠正实验过程中的偏颇与极端行为,教学过程逐步进入新的稳定阶段.教学过程逐步过渡到以问题为主线、 以活动为主线的! 无环节∀模式.( 2)受不同的教学理念影响, 教师角色、 学生角色、 教学目标、 教学过程关注点等方面, 在教学过程中有很大差异.教师角色 学生角色 教学目标 教学过程关注领导者(权威)接 受 者(被动)让 学 生 掌握 数 学 知识技能知识 引入, 讲 解本质, 巩固练习主导者(决定)观 察 者(协助)让 学 生 观摩 数 学 产生过程展示 过程, 注 重建构, 强化训练引导者(组织)参 与 者(主动)让 学 生 参与 探 究 数学 生 成 过程问题 情境, 提 出问题, 学生活动( 3) 2004 年高中数学课程改革后, 课堂教学发生一定的变化,广泛地进行! 创设情境∀! 提出问题∀!引导学生探究探索∀, 出现了以! 问题主线∀、! 活动主线∀为主的课堂, 出现了! 问题情境学生活动建立数学运用数学同顾反思∀的整体课堂构思.这些改变对于揭示数学的内在本质, 发展学生的思维能力起到积极的作用.( 4) 由于受多种因素制约(特别是高考) ,与初中相比, 本次课改后高中数学课堂教学变化幅度不大,近半数的课堂教学模式仍然以五环节为主.对于课改倡导的教学理念, 只是渗透在传统的教学模式中,目前高中数学课堂教学改革的力度、 深度与课改的预期目标还有一定的距离.我们看到2008 年的赛课教案的创新、 探索力度, 远没有1990 年的名师授课录 大, 那时还没有明确提出课改理念,但他们却进行积极的探索, 关注学生主体. 而今天,课改的理念已经系统培训 5 年, 许多教师仍停留在形式层面,未能变成自觉的行为.参考文献1 李善良. 我国数学教学设计的探索与评析# # # 兼及十年初中数学教师说课评比活动[ J ] . 中国数学教育(初中版) , 2007, 92 编委会. 名师授课录(中学数学高中版) [ M] , 上海教育出版社, 19913 2000 年全国首届高中青年数学教师优秀课观摩与评比的教案(会议资料)4 2008 年全国第四届高中青年数学教师优秀课观摩与评比的教案(会议资料)5 李善良. 关于数学教学中问题的设计[ J] . 高中数学教与学,2008, 129 2010 年 第49 卷 第2 期 数学通报
十指文学网 也是一个不错的文章网站!
论文中的参考文献应该按照相应的格式写。 专著[M]、论文集[C]、报纸文章[N]、期刊文章[J]、学位论文[D]、报告[R]、标准[S]、专利[P]、论文集中的
1、毕业论文的字数要求是对正文部分而言,比如本科论文8000字,指的是你正文部分。但是在查重的时候这些内容也是要检测的2、毕业论文总字数不算摘要和参考文献,指从
了解清楚论文包括摘要到底是一种怎么样的存在,是解决一切问题的关键。 既然如此, 论文包括摘要,发生了会如何,不发生又会如何。 俾斯麦说过一句著名的话,对于不
标准参考文献的来源应当是第一手的出处,也就是说你得首先能证明这个公众号的文章就是这段文字的作者。其次论文必须能提现作者的学术性和专业性,从公众号上摘录语句,难以