




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、約瑟夫生者死者游戲(鏈表存儲(chǔ))一:【內(nèi)容與要求】約瑟夫游戲的大意是:每30個(gè)旅客同乘一條船,因?yàn)閲?yán)重超載,加上風(fēng)高浪大,危險(xiǎn)萬(wàn)分;因此船長(zhǎng)告訴乘客,只有將全船一半的旅客投入還中,其余人才能幸免遇難。無(wú)奈,大家只得同意這種辦法,并議定30個(gè)人圍成一圈,由第一個(gè)人數(shù)起,依次報(bào)數(shù),數(shù)到第9人,便把他投入大海中,然后再?gòu)乃南乱粋€(gè)人數(shù)起,數(shù)到第9人,再將他扔進(jìn)大海中,如此循環(huán)地進(jìn)行,直到剩下15個(gè)乘客為止。問(wèn)哪些位置是將被扔下大海的位置。二:概要設(shè)計(jì)利用鏈表循環(huán)來(lái)解決。首先,就必須先定義一個(gè)鏈表,按照所需要的長(zhǎng)度進(jìn)行定義,然后令其為指針指向頭指針,即完成了一個(gè)循環(huán)鏈表的創(chuàng)建。接下來(lái)先打印鏈表輸出。其次
2、,就是算法實(shí)現(xiàn),需要利用指針來(lái)進(jìn)行,數(shù)據(jù)域標(biāo)記人員編號(hào),先用一個(gè)指針循環(huán)查找,找到第一個(gè)需要?jiǎng)h除的人,標(biāo)記為1,先輸出節(jié)點(diǎn)數(shù),再進(jìn)行刪除。依次循環(huán)查找,直到被刪除的節(jié)點(diǎn)數(shù)量為總?cè)藬?shù)的一半的時(shí)候則結(jié)束。:程序執(zhí)行流程圖三:詳細(xì)代碼結(jié)構(gòu)1 .鏈表的創(chuàng)建(1) 創(chuàng)建頭節(jié)點(diǎn)Josephring()(head=newNode;為頭結(jié)點(diǎn)申請(qǐng)空間head->no=1;/為數(shù)據(jù)域賦值head->next=head;/形成循環(huán)鏈表(2)循環(huán)插入鏈表voidJosephring二CreateJosephus(intn)(Node*s=head;/標(biāo)記頭結(jié)點(diǎn)totalnum=n;for(inti=2;i
3、<=n;i+)Node*w=newNode;/新建一個(gè)節(jié)點(diǎn)w->no=i;w->next=head;s->next=w;s=w;/S作為尾指針首先申請(qǐng)一個(gè)節(jié)點(diǎn),并且W指針指向它,然后從2開(kāi)始賦值,此時(shí)先令新節(jié)點(diǎn)的W指針指向頭結(jié)點(diǎn),再令S指針指向它,依次循環(huán)插入創(chuàng)建。2 .打印輸出鏈表voidJosephring:show()cout<<head->no<<"t"先輸出頭節(jié)點(diǎn)Node*q=head->next;while(q!=head)cout<<q->no<<"t"
4、;q=q->next;先打印輸出頭結(jié)點(diǎn),然后循環(huán)判定,將不等于頭結(jié)點(diǎn)的全部輸出。3 .程序主算法voidJosephring:Joseph(intk,intm)/從第k個(gè)人開(kāi)始數(shù)數(shù),數(shù)到m的人出列Node*p=head;/工作指針intj=1;/計(jì)數(shù)器while(j!=k)j+;p=p->next;/指針后移找到第k個(gè)人開(kāi)始數(shù)1的那個(gè)人for(inti=1;i<=totalnum/2;i+)Node*w=p;/指針w指向開(kāi)始數(shù)1的第k個(gè)人j=1;/計(jì)數(shù)器,為了找到數(shù)m的那個(gè)人while(j!=m)j+;p=w;w=w->next;找到了數(shù)m的那個(gè)人cout<<
5、;w->no<<"t"/輸出此人的編號(hào)p->next=w->next;/此人出列并刪除節(jié)點(diǎn)p=p->next;首先,先要找到第一個(gè)報(bào)數(shù)人的位置,用一個(gè)計(jì)數(shù)器進(jìn)行循環(huán)對(duì)比查找,從第一個(gè)位置起依次后移一個(gè)位置,直到輸入的數(shù)值等于鏈表上的某個(gè)位置數(shù)據(jù)域上的數(shù)值時(shí),停止查找并且標(biāo)記為P指針。其次,從P位置開(kāi)始,再用一個(gè)W指針標(biāo)記,兩個(gè)指針一次后移循環(huán)查找,當(dāng)W指針指向的數(shù)據(jù)域等于所輸入的報(bào)數(shù)間隔M時(shí),則打印輸出該節(jié)點(diǎn)上的數(shù)據(jù),并且刪除該節(jié)點(diǎn),P指針后移,作為下一次開(kāi)始數(shù)的起始位置。最后,依次循環(huán)打印輸出,知道人數(shù)為總?cè)藬?shù)的一半時(shí)候,程序停止。四:
6、運(yùn)行結(jié)果圖如下1.輸出船上的總?cè)藬?shù)輸入報(bào)數(shù)的起始位置"C:Userdmin-stratorDe5IrtopDebugsadaw,自2.強(qiáng)上的總?cè)藬?shù)為30w數(shù)起始的位置日?qǐng)?bào)數(shù)人間隔J輸入報(bào)數(shù)人的間隔之后便是最終界面3.五:設(shè)計(jì)過(guò)程主要問(wèn)題在設(shè)計(jì)過(guò)程中,開(kāi)始需要掌握是就是思想,主要就是鏈表的創(chuàng)建跟刪除,在設(shè)計(jì)過(guò)程中,我不知道如何去循環(huán)查找,以及如何循環(huán)輸出,因此剛剛開(kāi)始無(wú)從下手。之后我就開(kāi)始查找資料,網(wǎng)上參考別人的算法實(shí)現(xiàn),在去咨詢同學(xué)跟老師,最主要是這個(gè)程序不是很難,只要思想掌握好,了解指針鏈表的創(chuàng)建刪除就可以編寫(xiě)。因此在掌握好循環(huán)算法之后就可以完成編寫(xiě)。六:心得體會(huì)經(jīng)過(guò)本次的實(shí)訓(xùn),使
7、我得到了不少的收獲。使我的動(dòng)手能力有了一定的提升,并且學(xué)會(huì)了如何真正去設(shè)計(jì)一個(gè)簡(jiǎn)單的程序,在實(shí)訓(xùn)之前,我對(duì)程序整體的結(jié)構(gòu)基本上沒(méi)什么底子,自己從來(lái)沒(méi)完整的編寫(xiě)過(guò)一個(gè)程序,而這次無(wú)疑對(duì)我來(lái)說(shuō)我一個(gè)最好的練習(xí)。雖然每次去詢問(wèn)都是很簡(jiǎn)單的問(wèn)題,很遭反感,但是每次我都有收獲。本次實(shí)訓(xùn)的主要運(yùn)用就是鏈表,從而也加強(qiáng)了我對(duì)鏈表這反面的了解,最主要的收獲就是對(duì)程序整體的結(jié)構(gòu)以及其構(gòu)造,對(duì)我今后的學(xué)習(xí)有很大的幫助,今后我會(huì)多編寫(xiě)程序來(lái)提高自己的綜合水平。附錄:源程序完整代碼#include"iostream.h"#include"stdlib.h"#definemaxs
8、ize100/最大人數(shù)structNodeintno;/第幾個(gè)人Node*next;classJosephringprivate:Node*head;inttotalnum;public:Josephring()head=newNode;head->no=1;head->next=head;voidCreateJosephus(intn);voidshow();voidJoseph(intk,intm););voidJosephring:CreateJosephus(intn)/創(chuàng)建n個(gè)節(jié)點(diǎn)的鏈表(Node*s=head;totalnum=n;for(inti=2;i<=n;
9、i+)(Node*w=newNode;w->no=i;w->next=head;s->next=w;s=w;)voidJosephring:show()/輸出鏈表(cout<<head->no<<"t"Node*q=head->next;while(q!=head)(cout<<q->no<<"t"q=q->next;)voidJosephring:Joseph(intk,intm)/從第k個(gè)人開(kāi)始數(shù)數(shù),數(shù)到m的人出列(Node*p=head;/工作指針intj=1
10、;/計(jì)數(shù)器while(j!=k)(j+;p=p->next;/指針后移找到第k個(gè)人開(kāi)始數(shù)1的那個(gè)人for(inti=1;i<=totalnum/2;i+)(Node*w=p;/指針w指向開(kāi)始數(shù)1的第k個(gè)人Node*q;j=1;計(jì)數(shù)器,為了找到數(shù)m的那個(gè)人while(j!=m)(j+;q=w;w=w->next;/找到了數(shù)m的那個(gè)人cout<<w->no<<"t"/輸出此人的編號(hào)q->next=w->next;/此人出列并刪除節(jié)點(diǎn)p=q->next;intmain()(intk,m;/船上的總數(shù),k為從第幾個(gè)人
11、開(kāi)始數(shù),m為數(shù)到m的那個(gè)人出列Josephringjosephus;cout<<"船上的總?cè)藬?shù)為:"cin>>k;while(k>maxsize|k<0)(cout<<"超出范圍,請(qǐng)重新輸入:"cin>>k;cout<<endl;cout<<endl<<endl;josephus.CreateJosephus(k);cout<<"報(bào)數(shù)起始的位置:"cin>>k;cout<<endl<<endl<<"報(bào)數(shù)人間隔:";cin>>m;cout<<endl<<endl;cout&l
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 小考畢業(yè)測(cè)試題及答案
- 家具設(shè)計(jì)軟件應(yīng)用及考察試題及答案
- 耐藥結(jié)核病試題及答案
- 簡(jiǎn)單幾何圖形的識(shí)別試題及答案
- 黃浦區(qū)面試真題及答案
- 環(huán)藝面試筆試題目及答案
- 2025年主題公園行業(yè)品牌競(jìng)爭(zhēng)力研究報(bào)告:市場(chǎng)現(xiàn)狀與未來(lái)展望
- 2025飛行技能測(cè)試題目及答案
- 金融衍生品市場(chǎng)2025年創(chuàng)新產(chǎn)品風(fēng)險(xiǎn)評(píng)估與防控策略報(bào)告
- 基于5G技術(shù)的2025年智慧港口自動(dòng)化裝卸設(shè)備通信解決方案報(bào)告
- 第二章中國(guó)體育產(chǎn)業(yè)的發(fā)展與現(xiàn)狀
- 靜脈炎的護(hù)理 課件
- DB3303T078-2024規(guī)模以上工業(yè)企業(yè)健康評(píng)價(jià)指標(biāo)體系
- 特種作業(yè)合同協(xié)議
- 《工程勘察設(shè)計(jì)收費(fèi)標(biāo)準(zhǔn)》(2002年修訂本)
- 人工髖關(guān)節(jié)置換術(shù)后的護(hù)理 課件
- 九州通集團(tuán)簡(jiǎn)介
- 五年級(jí)語(yǔ)文下冊(cè)第七單元【教材解讀】-【單元預(yù)習(xí)課】課件
- 市場(chǎng)管理及產(chǎn)品規(guī)劃課件培訓(xùn)課件(PPT-202張)
- 超深水油田開(kāi)發(fā)及水下生產(chǎn)系統(tǒng)概述-37頁(yè)的簡(jiǎn)介
- 太湖縣趙氏宗譜編纂理事會(huì)章程
評(píng)論
0/150
提交評(píng)論