——以“猴子選大王”程序為例"/>
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-),男,四川犍為。

主站蜘蛛池模板: 欧美午夜在线观看| 美女啪啪无遮挡| 国产乱子伦视频在线播放| 就去色综合| 国产熟睡乱子伦视频网站| 毛片免费在线视频| 日韩精品久久无码中文字幕色欲| a级毛片网| 久久中文无码精品| 国产综合亚洲欧洲区精品无码| 2024av在线无码中文最新| 亚洲欧洲日韩国产综合在线二区| 色综合久久88| 九九视频免费在线观看| 国产网站一区二区三区| 激情无码视频在线看| 小13箩利洗澡无码视频免费网站| 国产激情在线视频| 免费国产小视频在线观看| 久久永久视频| 亚洲日韩精品伊甸| 国产91麻豆视频| 国产91熟女高潮一区二区| 国产综合在线观看视频| 国产麻豆精品手机在线观看| 国产午夜一级淫片| 国产美女精品一区二区| 亚欧乱色视频网站大全| 欧美国产在线一区| 日韩欧美国产精品| 日韩a在线观看免费观看| 国产91小视频在线观看| 久久黄色毛片| 精品夜恋影院亚洲欧洲| 亚洲欧美在线综合图区| 欧美亚洲一二三区| 狠狠v日韩v欧美v| 亚洲天堂啪啪| 亚洲一区二区三区中文字幕5566| 久久综合九色综合97婷婷| 久久99国产精品成人欧美| 国产在线精品99一区不卡| 国产福利一区在线| 久久99精品久久久久久不卡| 9久久伊人精品综合| 国禁国产you女视频网站| 极品av一区二区| 91精品aⅴ无码中文字字幕蜜桃| 免费人欧美成又黄又爽的视频| 欧美在线网| 亚洲综合经典在线一区二区| 97在线碰| 97免费在线观看视频| 精品国产免费人成在线观看| 试看120秒男女啪啪免费| 国产青青操| 青青久视频| 91精品免费久久久| 欧美成人午夜视频免看| 无码内射在线| 伊人无码视屏| 老司国产精品视频| 在线观看无码av免费不卡网站 | 99ri国产在线| 亚洲性日韩精品一区二区| 无码精品国产dvd在线观看9久| 亚洲视频色图| 国产亚洲精品91| 91精品视频网站| 国产免费羞羞视频| 永久免费av网站可以直接看的| 青草视频久久| 婷婷综合在线观看丁香| 欧美国产日本高清不卡| 亚洲人成网站在线观看播放不卡| 国产午夜福利在线小视频| 国产一级做美女做受视频| 亚洲va视频| 日韩不卡免费视频| 久久精品91麻豆| 国产成人麻豆精品| 日韩高清一区 |