亚洲免费av电影一区二区三区,日韩爱爱视频,51精品视频一区二区三区,91视频爱爱,日韩欧美在线播放视频,中文字幕少妇AV,亚洲电影中文字幕,久久久久亚洲av成人网址,久久综合视频网站,国产在线不卡免费播放

        ?

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

        2016-06-21 03:01:37
        無線互聯(lián)科技 2016年9期
        關(guān)鍵詞:模擬鏈表

        王 勝

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

        ?

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

        王勝

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

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

        關(guān)鍵詞:猴子選大王;模擬;鏈表;stl l ist;數(shù)學推導

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

        1 模擬靜態(tài)數(shù)組法

        學習了靜態(tài)數(shù)組后,可以直接用靜態(tài)數(shù)組來模擬淘汰的過程。

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

        優(yōu)點:理解容易,代碼較易實現(xiàn)。

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

        2 模擬鏈表法

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

        優(yōu)點:執(zhí)行效率比數(shù)組高,只掃描不判斷,提高了運行時間,臨時開辟存儲空間,不用預先定義避免了內(nèi)存浪費。

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

        3 stl list實現(xiàn)

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

        優(yōu)點:代碼簡潔,很好的實現(xiàn)了模擬淘汰的操作。

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

        4 數(shù)學推導法

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

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

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

        這是一個n-1個人的問題,如果能從n-1個人問題的解推出n個人問題的解,從而得到一個遞推公式,那么問題就解決了。假如我們已經(jīng)知道了n-1個人時,最后勝利者的編號為x,利用映射關(guān)系逆推,就可以得出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)第二個被刪除的數(shù)為(m - 1) % (n - 1)。

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

        這是一個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的數(shù)值,最后結(jié)果是f[n]。因為實際生活中編號總是從1開始,我們輸出f[n]+1,由于是逐級遞推,甚至不需要保存每個f,程序也是異常簡單:

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

        優(yōu)點:運行速度快,代碼簡練。

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

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

        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-),男,四川犍為。

        猜你喜歡
        模擬鏈表
        基于二進制鏈表的粗糙集屬性約簡
        跟麥咭學編程
        基于鏈表多分支路徑樹的云存儲數(shù)據(jù)完整性驗證機制
        C++的基于函數(shù)模板實現(xiàn)單向鏈表
        丙酮—甲醇混合物萃取精餾分離過程合成與模擬
        讓學引思:讓學生做主
        考試周刊(2016年96期)2016-12-22 23:20:42
        一個高分子模擬計算網(wǎng)格的作業(yè)管理
        工業(yè)機器人模擬仿真技術(shù)在職業(yè)教育中的應用淺析
        淺析柔道運動員的模擬實戰(zhàn)訓練
        體育時空(2016年9期)2016-11-10 21:18:16
        虛擬機局域網(wǎng)組建技術(shù)應用初探
        一区二区三区在线日本| 色婷婷五月综合亚洲小说| 曰韩精品无码一区二区三区| 青青草久热手机在线视频观看 | 国产免费网站在线观看不卡| 亚洲 日本 欧美 中文幕| 人妻在线日韩免费视频| 不卡国产视频| 国产白浆一区二区三区佳柔| 无码国产精品一区二区免费式芒果| 午夜福利麻豆国产精品| 一本无码av一区二区三区| 国产偷拍自拍在线观看| 欧美a级毛欧美1级a大片| 成人欧美一区二区三区的电影| 99热成人精品国产免| 久久久噜噜噜久久熟女| 国产成人亚洲精品无码青| 无码三级在线看中文字幕完整版| 久久久久久免费播放一级毛片| 亚洲成av人片极品少妇| 国产成人无码精品久久久露脸| 国产禁区一区二区三区| 亚洲国产午夜精品理论片在线播放| 一本色道久久综合亚洲精品小说| 中文字幕你懂的一区二区| 99国产精品久久99久久久| 久久亚洲精品成人av| 男人阁久久| 日本不卡一区二区三区久久精品| 欧美人牲交| 欧美激情二区| 日本高清人妻一区二区| 免费无遮挡无码永久在线观看视频| 精品国产一区二区三区久久狼| 中文亚洲成a人片在线观看| 日本视频一中文有码中文| 日日婷婷夜日日天干| 中文字幕人妻中文| 亚洲高清一区二区精品| 丁香美女社区|