——以“猴子選大王”程序為例"/>
999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

模擬淘汰程序的設計方法研究
——以“猴子選大王”程序為例

2016-06-21 03:01:37
無線互聯科技 2016年9期

王 勝

(犍為外國語實驗學校,四川 犍為 614400)

?

模擬淘汰程序的設計方法研究
——以“猴子選大王”程序為例

王勝

(犍為外國語實驗學校,四川犍為614400)

摘要:猴子選大王是一道經典的程序設計題,文章指出,可以通過不同的設計方法來實現:(1)模擬數組法。(2)模擬鏈表法。(3)stl l ist實現。(4)數學推導法。

關鍵詞:猴子選大王;模擬;鏈表;stl l ist;數學推導

問題:n只猴子圍成一個圈。從第一只猴子開始,從1開始依次報數,報到m的猴子離開。從這只離開猴子的下一只開始再從1開始報數,報到m的再離開。以此類推,直到最后剩下一只猴子為止。這只剩下的猴子就是大王。現在編寫程序,輸入n和m,輸出大王的號碼。

1 模擬靜態數組法

學習了靜態數組后,可以直接用靜態數組來模擬淘汰的過程。

原理:設置n+1數組,初值為0,表示n只猴子都在圈子里,淘汰的猴子賦值為1。從數組1開始掃描,查看對應的值是否為0并計數,掃描到m個0后,把對應數組的值修改為1,表示淘汰。繼續執行下一步的操作,直到里面只剩下一只猴子結束。最后從1開始掃描數組,找到一個為0的結束,該下標對應的猴子為大王。關鍵:0,1表示猴子是否在圈中,掃描的時候忽略不在的猴子,設置結束標記,能正常結束。

優點:理解容易,代碼較易實現。

缺點:效率差,每次都要掃描全部的數據,還要判斷該位置上是否有猴子。對于大一些的數據運行時間長。

2 模擬鏈表法

數組法在淘汰過程中要不斷判斷對應的值是否為0,即猴子是否在圈內,掃描判斷效率低。學習鏈表后,我們可以用環形鏈表實現,每個節點代表一個猴子,掃描淘汰過程中直接刪除該結點,避免了判斷及重復掃描浪費時間。

優點:執行效率比數組高,只掃描不判斷,提高了運行時間,臨時開辟存儲空間,不用預先定義避免了內存浪費。

缺點:鏈表理解編寫有一定的難度。

3 stl list實現

自從有了stl后,可借助里面的容器list(鏈表)快速實現鏈表功從而進行程序設計及代碼的編寫。解題思路:生成一圈猴子,邊掃描邊刪除,快速模擬淘汰過程。

優點:代碼簡潔,很好的實現了模擬淘汰的操作。

缺點:學習新的程序知識。

4 數學推導法

模擬法效率很低,其時間復雜度為O(mn)。當n和m很大時,很難在短時間內得出結果。如果能得出一個通式,就可以利用遞推來快速解決。下面給出推導的過程(假設從0到N-1):

(1)第一個被刪除的數為(m-1)%n。

(2)假設第二輪的開始數字為k,那么這n-1個數構成的約瑟夫環為k,k+1,k+2,k+3,.....,k-3,k-2。做一個簡單的映射。

這是一個n-1個人的問題,如果能從n-1個人問題的解推出n個人問題的解,從而得到一個遞推公式,那么問題就解決了。假如我們已經知道了n-1個人時,最后勝利者的編號為x,利用映射關系逆推,就可以得出n個人時,勝利者的編號為(x + k)%n。其中k等于m%n。代入(x + k) % n<=>(x + (m % n))%n <=> (x%n + (m%n)%n)%n <=> (x%n+m%n)%n <=>(x+m)%n。

(3)第二個被刪除的數為(m - 1) % (n - 1)。

(4)假設第三輪的開始數字為o,那么這n - 2個數構成的約瑟夫環為o,o+1,o+2,......o-3,o-2.。繼續做映射。

這是一個n-2個人的問題。假設最后的勝利者為y,那么n-1個人時,勝利者為(y+o)%(n-1),其中o等于m%(n-1)。代入可得(y+m)%(n-1), 要得到n-1個人問題的解,只需得到n-2個人問題的解,倒推下去。只有一個人時,勝利者就是編號0。下面給出遞推式:

f[1]=0;

f[ i ]=( f [i -1] + m)%i; (i>1)

有了這個公式,我們要做的就是從1-n順序算出f的數值,最后結果是f[n]。因為實際生活中編號總是從1開始,我們輸出f[n]+1,由于是逐級遞推,甚至不需要保存每個f,程序也是異常簡單:

Intans[10000]={0},i,n,m; //ans數組保存結果,還可用stl 中vector容器,甚至用一個變量代替。式進行計算

優點:運行速度快,代碼簡練。

缺點:數學推導過程要仔細推敲,慢慢消化理解。

對于猴子選大王這類環形問題,我們可以用不同的方法、不同的技術來解決,如何選擇最優的設計方案呢,這就要我們在平時的學習中不斷的積累知識,多思善想。適當地運用數學策略,不僅可以讓編程變得簡單,而且往往會成倍地提高算法執行效率。在此拋磚引玉,希望大家能提出更優、更易解決問題的方法。

Research on Simulation Program Design Method:Taking Choose Monkey King Program as an Example

Wang Sheng
(Qianwei Foreign Language Experimental School, Qianwei614400, China)

Abstract:Choose Monkey King is a classic programming problem, the article points out that can be done by different design methods: (1) the simulation method of array. (2) simulation list. (3) the stl list implementation. (4) mathematical deduction.

Key words:choose monkey king; simulation; list; stl list; mathematical deduction

作者簡介:王勝(1975-),男,四川犍為。

主站蜘蛛池模板: 亚洲Va中文字幕久久一区| 日韩国产另类| 91探花在线观看国产最新| 久久精品国产精品国产一区| 91精品啪在线观看国产60岁| 久久午夜夜伦鲁鲁片无码免费| 亚洲天天更新| 欧美国产综合视频| A级全黄试看30分钟小视频| 88av在线播放| 又粗又硬又大又爽免费视频播放| 试看120秒男女啪啪免费| 亚洲综合婷婷激情| 国产视频 第一页| 波多野结衣在线一区二区| 亚洲午夜综合网| 欧美a级完整在线观看| 久久综合五月| 国产区在线看| 国产理论精品| 日韩在线网址| 中文字幕天无码久久精品视频免费| 精品视频第一页| 91香蕉国产亚洲一二三区| 国产一区二区影院| 成人一级黄色毛片| 天天爽免费视频| 色网站免费在线观看| 五月婷婷激情四射| 99久久精品国产麻豆婷婷| 国产欧美日韩资源在线观看| 欧洲精品视频在线观看| 亚洲系列无码专区偷窥无码| 午夜在线不卡| 国产第二十一页| 国产一区二区网站| 亚洲国产中文欧美在线人成大黄瓜 | 美女高潮全身流白浆福利区| 国产精品亚洲天堂| 国产性爱网站| 国产综合日韩另类一区二区| 国产免费福利网站| 国产麻豆永久视频| 激情午夜婷婷| 成年午夜精品久久精品| 日本午夜在线视频| 超清无码熟妇人妻AV在线绿巨人| 久青草免费在线视频| 亚洲无码久久久久| 无码精油按摩潮喷在线播放| 国产精品无码作爱| 午夜精品区| 尤物午夜福利视频| 婷婷99视频精品全部在线观看| 国产精品入口麻豆| 国产精品久久精品| 免费av一区二区三区在线| 丁香五月激情图片| 欧美亚洲国产一区| 又黄又湿又爽的视频| 亚洲成a人在线观看| 91探花国产综合在线精品| 91精品情国产情侣高潮对白蜜| 高清亚洲欧美在线看| 乱人伦视频中文字幕在线| 亚洲欧美在线综合图区| 中文字幕资源站| 中文字幕亚洲乱码熟女1区2区| 久久国产黑丝袜视频| 狠狠躁天天躁夜夜躁婷婷| 亚洲精品国偷自产在线91正片| 国产精品视频猛进猛出| 毛片一级在线| 国产精品香蕉| 亚洲香蕉久久| 国产午夜一级淫片| 国产中文一区a级毛片视频| 欧美综合区自拍亚洲综合绿色 | 91外围女在线观看| 58av国产精品| 高清不卡一区二区三区香蕉| 狠狠色狠狠综合久久|