Loading AI tools
中国古代数学中算数方法 来自维基百科,自由的百科全书
盈不足术是中国古代数学的一种算术方法。西汉成书的算学经典《九章算术》的第七章即名为“盈不足”。狭义的盈不足术指典型的盈亏问题的算法。广义的盈不足术则指透过双假设法将其他数学问题转化为盈亏问题、再用机械化算法求解的方法。[1][2]
《九章算数》原文 | 解释 | 抽象算法 | 具体代入 |
---|---|---|---|
今有共买鸡 | 一群人一起买鸡 | ||
人出九,盈十一 | 每人出 9 块,合起来多出 11 块 | 记每人出的钱为 ,多出的钱为 | |
人出六,不足十六 | 每人出 6 块,合起来差 16 块 | 记每人出的钱为 ,差的钱为 | |
问︰人数、鸡价各几何? | 人数和鸡的总价分别是多少? | ||
盈不足术曰 | “盈不足术”的算法如下 | ||
置所出率,盈、不足各居其下 | 写出每人出了多少钱,把多出和差的钱分别对应地写在其下 | ||
令维乘所出率,并以为实 | 交叉相乘,再相加,作为被除数(“实”) | ||
并盈、不足为法 | 把多出和差的钱加起来,作为除数(“法”) | ||
实如法而一 | 被除数除以除数 (所得即为不盈不亏时的条件) |
||
盈不足相与同其买物者,置所出率,以少减多,馀 | 写出多出时和不足时每人两次分别出了多少钱,用大数减去小数,得到“余” | ||
以约法、实
实为物价,法为人数 |
“余”除“实”,得到物价 “余”除“法”得到人数 |
||
答曰:九人,鸡价七十 | 共有 9 个人,总价为 70 块 |
刘徽在为《九章算术》作注时,利用齐同原理对盈不足术进行了证明:“盈朒维乘两设者,欲为同齐之意。……齐其假令,同其盈朒……通计齐则不盈不朒之正数,故可并之为实,并盈、不足为法。”[3]:291
刘徽指出,交叉相乘的意义是使其“同齐”。每人所出为 时,盈 ,那么总价变为 倍、每人所出变为 时,盈 。每人所出为 时,不足 ,那么总价变为 倍、每人所出变为 时,不足 。这样就“同其盈朒”,两者相加则盈亏相抵,就“不盈不朒”,此时总价为 倍,每人所出为 ,相除即得到总价不变时每人所出的钱。
除盈亏类问题,《九章算术》还通过双假设法,将其他算术问题转化、套入盈亏类问题的算法模型,进行求解。如:
该问题本属于鸡兔同笼,而通过两次假设可以将其转化为盈亏类问题,再用盈不足术求解。
盈不足术实际上是一种线性插值法;对于非线性的问题,所求出的只是其近似值。《九章算术》和刘徽都没有意识到这一点。[3]:302如:
实际上该问题是非线性的。根据等比数列求和公式,可以将莞草与蒲草的长度差表示为:
而使用盈不足术所求出的答案实为近似值。两者关系见右图。
在中国最早的数学书《算数书》中,就有通过盈不足术计算面积为一亩的正方形田地的边长的记载。[4]《九章算术》第七章“盈不足”,则是对双假设法最早的详细说明。[5]:116
伊斯兰黄金时代的阿拉伯数学家也大量研究了双假设法。阿布·卡米勒著有《双假设法之书》(Kitāb al-khaṭaʾayn)。古斯塔·伊本·卢卡采用欧式几何的方法,第一次对双假设法给出了几何证明。[5]:117
中世纪欧洲数学家斐波那契在《计算之书》的第十三章中讨论了双假设法。他明确承认该方法来自阿拉伯数学,并称之为 elchataym,即来自阿拉伯语的 al-khaṭāʾayn。[6]在代数符号尚未普及的时代,这种万能算法在欧洲流传甚广,兴盛一时。[5]:116、118、127
明朝时,中国传统数学已经衰落,《九章算术》近乎失传,盈不足术不为人所知。利玛窦和李之藻将克里斯托弗·克拉维乌斯的《实用算术概论》(Epitome arithmeticae practicae)编译为《同文算指》,将其中的双假设法称为“叠借互征法”。[5]:130
钱宝琮最早提出,阿拉伯数学中的双假设法来自中国的盈不足术,al-khaṭāʾayn 即与“契丹”有关。[7]李约瑟也认为有此种可能性。[8]这种说法已被中国数学史界广泛接受;但也有学者认为,中国盈不足术是欧洲双假设法的源头的说法仍然缺乏令人信服的证据支持。[5]:137
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.