數(shù)學(xué)名師導(dǎo)航算法案例_第1頁(yè)
數(shù)學(xué)名師導(dǎo)航算法案例_第2頁(yè)
數(shù)學(xué)名師導(dǎo)航算法案例_第3頁(yè)
數(shù)學(xué)名師導(dǎo)航算法案例_第4頁(yè)
數(shù)學(xué)名師導(dǎo)航算法案例_第5頁(yè)
已閱讀5頁(yè),還剩5頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

學(xué)必求其心得,業(yè)必貴于專精學(xué)必求其心得,業(yè)必貴于專精學(xué)必求其心得,業(yè)必貴于專精5.4算法案例名師導(dǎo)航三點(diǎn)剖析一、“韓信點(diǎn)兵-—孫子問(wèn)題”的算法在“韓信點(diǎn)兵”的問(wèn)題中,當(dāng)士兵排成3列縱隊(duì),結(jié)果多余2人說(shuō)明士兵的總?cè)藬?shù)除以3之后余數(shù)是2,所以算法步驟就是將所有除以3之后余數(shù)是2的正整數(shù)找出來(lái),按照從小到大的順序排成一列數(shù);當(dāng)士兵排成5列縱隊(duì),結(jié)果多余3人說(shuō)明士兵的總?cè)藬?shù)除以5之后余數(shù)是3,所以算法步驟就是將所有除以5之后余數(shù)是3的正整數(shù)找出來(lái),按照從小到大的順序排成一列數(shù);當(dāng)士兵排成7列縱隊(duì),結(jié)果多余2人說(shuō)明士兵的總?cè)藬?shù)除以7之后余數(shù)是2,所以算法步驟就是將所有除以7之后余數(shù)是2的正整數(shù)找出來(lái),按照從小到大的順序排成一列數(shù).這樣完成上述步驟之后,就找到了“韓信點(diǎn)兵”問(wèn)題的一個(gè)算法,從而也得出了解決“孫子問(wèn)題”的算法。我國(guó)古代數(shù)學(xué)的發(fā)展有著自己的鮮明特色,走著與西方完全不同的道路,即使今天看來(lái),這條路仍然有很大的優(yōu)越性.這條道路的一個(gè)重要特色就是“寓理于算”,即把要解決的問(wèn)題“算法化"。本節(jié)中案例1直接體現(xiàn)了我國(guó)古代算法在數(shù)學(xué)和計(jì)算機(jī)程序設(shè)計(jì)中的廣泛應(yīng)用。二、求兩個(gè)正整數(shù)最大公約數(shù)的算法.求兩個(gè)正整數(shù)的最大公約數(shù)的算法常見(jiàn)的有“歐幾里得輾轉(zhuǎn)相除法”和“更相減損術(shù)".1.“歐幾里得輾轉(zhuǎn)相除法"求兩個(gè)正整數(shù)a、b(a>b)的最大公約數(shù),可以歸結(jié)為求一數(shù)列:a,b,r1,r2,…,rn-1,rn,rn+1,0。此數(shù)列的首項(xiàng)與第二項(xiàng)是a和b,從第三項(xiàng)開(kāi)始的各項(xiàng),分別是前兩項(xiàng)相除所得的余數(shù),如果余數(shù)為0,它的前項(xiàng)rn+1即是a和b的最大公約數(shù).其步驟是:計(jì)算出a除以b的余數(shù)r,若r=0,則b為a、b的最大公約數(shù);若r≠0,則把b作為被除數(shù),把余數(shù)r作為除數(shù),繼續(xù)運(yùn)算,直到余數(shù)為0,此時(shí)的除數(shù)即為自然數(shù)a、b的最大公約數(shù).2?!案鄿p損術(shù)”“更相減損術(shù)”是我國(guó)的《九章算術(shù)》中提到的一種求兩個(gè)正數(shù)最大公約數(shù)的算法,它與“輾轉(zhuǎn)相除法”相似.它的基本思想是:讓兩個(gè)數(shù)中較大的數(shù)減去較小的數(shù),以差和較小的數(shù)組成一對(duì)新數(shù),再比較兩數(shù)的大小,然后讓兩數(shù)中較大的數(shù)減去較小的數(shù),以同樣的操作一直做下去,直到產(chǎn)生一對(duì)相等的數(shù)為止,這個(gè)數(shù)就是兩個(gè)數(shù)的最大公約數(shù).從某種意義上說(shuō),“更相減損術(shù)"就是“歐幾里得輾轉(zhuǎn)相除法”.問(wèn)題探究問(wèn)題1:古今中外,許多人致力于圓周率的研究與計(jì)算.為了計(jì)算出圓周率的越來(lái)越好的近似值,一代代的數(shù)學(xué)家為這個(gè)神秘的數(shù)貢獻(xiàn)了無(wú)數(shù)的時(shí)間與心血。我國(guó)東漢的數(shù)學(xué)家劉徽利用“割圓術(shù)”計(jì)算圓的面積及圓周率π?!案顖A術(shù)”被稱為千古絕技,它的原理是用圓內(nèi)接正多邊形的面積去逼近圓的面積,具體計(jì)算如下:在單位圓內(nèi)作內(nèi)接正六邊形,其面積記為A1,邊長(zhǎng)記為a1,在此基礎(chǔ)上作圓內(nèi)接正12邊形,面積記為A2,邊長(zhǎng)為a2……一直作下去,記該圓的內(nèi)接正6×2n-1邊形面積為An,邊長(zhǎng)為an.由于所考慮的是單位圓,計(jì)算出的An即為圓周率π的近似值,n越大,An與π越接近。你能設(shè)計(jì)這樣計(jì)算圓周率的一個(gè)算法嗎?圖5—31探究:應(yīng)首先推導(dǎo)出an,an-1,An,An-1的關(guān)系。如圖531所示,設(shè)PQ為圓內(nèi)接正6×2n-1邊形的一邊,即PQ=an-1,OR為與PQ垂直的半徑,R為PQ弧的平分點(diǎn),顯然PR=an.a1=1,通過(guò)上面兩式,從a1=1開(kāi)始進(jìn)行迭代,可逐步計(jì)算出an與An.由于所考慮的是單位圓,計(jì)算出的An即為圓周率π的近似值,n越大,An與π越接近。算法和流程圖如下:Readn1←aForIfrom2tonA←3×2I-2×aa←Sqrt[2-2×Sqrt[1-a2/4]];PrintI,A,aEndforEnd流程圖(如圖5—32所示):圖5-32問(wèn)題2:據(jù)我國(guó)古書(shū)《唐闕史》記載,公元855年前后,有一次,青州府要從兩個(gè)辦事員中選拔一人當(dāng)官,但是這兩個(gè)辦事員的職務(wù)、資歷、能力和成績(jī)、表現(xiàn)并無(wú)顯著的差異,而名額只有一個(gè),提升誰(shuí)?負(fù)責(zé)提升的官員感到十分為難,就去請(qǐng)教青州的地方官楊塤.楊塤考慮了很久,想出了一個(gè)主意,他說(shuō):“官員應(yīng)該能寫(xiě)會(huì)算,你把他們叫來(lái),我出一道題當(dāng)場(chǎng)考考他們,誰(shuí)先算出就提升誰(shuí)。”同時(shí),楊塤讓人把他出的題抄成兩份,負(fù)責(zé)提升的官員找來(lái)兩位辦事員,給每人一袋算籌,一聲令下兩個(gè)人開(kāi)始解題,不一會(huì)兒,其中一個(gè)先算出了正確答案,楊塤當(dāng)場(chǎng)宣布提升他。大家都認(rèn)為楊塤這種辦法比較公允。在古代,像這樣用“數(shù)學(xué)競(jìng)賽"來(lái)決定官員晉升是為數(shù)不少的.題目的大意如下:一天夜里,有一個(gè)人在林中散步,無(wú)意中聽(tīng)到幾個(gè)強(qiáng)盜在商量怎樣分配搶來(lái)的布匹,只聽(tīng)見(jiàn)他們說(shuō):“如果每人分6匹,就剩5匹;如果每人分7匹,就差8匹.”問(wèn)有強(qiáng)盜幾個(gè)?布匹多少?能用一個(gè)簡(jiǎn)單算法求出強(qiáng)盜個(gè)數(shù)和布匹數(shù)嗎?探究:中國(guó)古代的《九章算術(shù)》一書(shū)中搜集了許多這類問(wèn)題,各題都有完整的解法,后人稱這種算法為-—“盈不足術(shù)”。這種算法可以概括為兩句口訣:有余加不足,大減小來(lái)除。公式:(盈+不足)÷兩次所得之差=人數(shù),每人所得數(shù)×人數(shù)+盈=物品總數(shù),求得強(qiáng)盜有(8+5)÷(7-6)=13(人),布匹有6×13+5=83(匹)。偽代碼:Reada,b,c,dx←(a+b)/(d-c)y←cx+aprintx,y流程圖(如圖5—33所示):圖5-33除此之外,這個(gè)問(wèn)題可看作二元一次方程組問(wèn)題.問(wèn)題的特點(diǎn)是給出兩種分配方案,一種分法分不完,一種分法不夠分。所以,本題還有一種方法,就是利用二元一次方程組的方法來(lái)解題。首先,根據(jù)題意設(shè)有強(qiáng)盜x個(gè),布匹y匹,則可列出二元一次方程如下:6x=y-5,7x=y+7。然后再根據(jù)解二元一次方程組的算法寫(xiě)出該題的算法即可。精題精講例1.求1734,816,1343的最大公約數(shù)。思路解析三個(gè)數(shù)的最大公約數(shù)分別是每個(gè)數(shù)的約數(shù),因此也是任意兩個(gè)數(shù)的最大公約數(shù)的約數(shù),也就是說(shuō)三個(gè)數(shù)的最大公約數(shù)是其中任意兩個(gè)數(shù)的最大公約數(shù)與第三個(gè)數(shù)的最大公約數(shù)。解:用“輾轉(zhuǎn)相除法"。先求1734和816的最大公約數(shù),1734=816×2+102;816=102×8;所以1734與816的最大公約數(shù)為102。再求102與1343的最大公約數(shù),1343=102×13+17;102=17×6。所以1343與102的最大公約數(shù)為17,即1734,816,1343的最大公約數(shù)為17.綠色通道求兩個(gè)正整數(shù)a、b(a〉b)的最大公約數(shù),可以歸結(jié)為求一數(shù)列:a,b,r1,r2,…,rn-1,rn,rn+1,0,此數(shù)列的首項(xiàng)與第二項(xiàng)是a和b,從第三項(xiàng)開(kāi)始的各項(xiàng),分別是前兩項(xiàng)相除所得的余數(shù),如果余數(shù)為0,它的前項(xiàng)rn+1即是a和b的最大公約數(shù),這種方法叫做“歐幾里得輾轉(zhuǎn)相除法”。例2.猴子吃桃問(wèn)題:有一堆桃子不知數(shù)目,猴子第一天吃掉一半,覺(jué)得不過(guò)癮,又多吃了一只,第二天照此辦法,吃掉剩下桃子的一半另加一個(gè),天天如此,到第十天早上,猴子發(fā)現(xiàn)只剩一只桃子了,問(wèn)這堆桃子原來(lái)有多少個(gè)?思路解析此題粗看起來(lái)有些無(wú)從著手的感覺(jué),那么怎樣開(kāi)始呢?假設(shè)第一天開(kāi)始時(shí)有a1只桃子,第二天有a2只,…,第9天有a9只,第10天有a10只。在a1,a2,…,a10中,只有a10=1是知道的,現(xiàn)要求a1,而我們可以看出a1,a2,…,a10之間存在一個(gè)簡(jiǎn)單的關(guān)系:a9=2×(a10+1),a8=2×(a9+1),…a1=2×(a2+1)。也就是:ai=2×(ai+1+1),i=9,8,7,6,…,1。這就是此題的數(shù)學(xué)模型。再考察上面從a9,a8直至a1的計(jì)算過(guò)程,這其實(shí)是一個(gè)遞推過(guò)程,這種遞推的方法在計(jì)算機(jī)解題中經(jīng)常用到.另一方面,這九步運(yùn)算從形式上完全一樣,不同的只是ai的下標(biāo)而已。由此,我們引入循環(huán)的處理方法,并統(tǒng)一用a0表示前一天的桃子數(shù),a1表示后一天的桃子數(shù)。解:本題的算法如下:S1a1←1;{第10天的桃子數(shù),a1S2i←9;{計(jì)數(shù)器初值為9}S3a0←2×(a1+1S4a1←a0S5i←i-1;S6若i≥1,轉(zhuǎn)S3;S7輸出a0的值。偽代碼如下:10a1←20i←930a0←2×(a1+140a1←a50i←i-160If

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論