數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 敢死隊問題

上傳人:仙*** 文檔編號:33568979 上傳時間:2021-10-18 格式:DOC 頁數(shù):18 大小:410.51KB
收藏 版權(quán)申訴 舉報 下載
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 敢死隊問題_第1頁
第1頁 / 共18頁
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 敢死隊問題_第2頁
第2頁 / 共18頁
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 敢死隊問題_第3頁
第3頁 / 共18頁

下載文檔到電腦,查找使用更方便

15 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 敢死隊問題》由會員分享,可在線閱讀,更多相關(guān)《數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 敢死隊問題(18頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、 課 程 設(shè) 計(數(shù)據(jù)結(jié)構(gòu))班 級計科1003姓 名 學(xué) 號1011051093 指導(dǎo)教師 二一一年一月十日課程設(shè)計任務(wù)書及成績評定課題名稱 敢死隊問題 、題目的目的和要求: 鞏固和加深對數(shù)據(jù)結(jié)構(gòu)的理解,通過上機(jī)實驗、調(diào)試程序,加深對課本知識的理解,最終使學(xué)生能夠熟練應(yīng)用數(shù)據(jù)結(jié)構(gòu)的知識寫程序。(1)通過本課程的學(xué)習(xí),能熟練掌握幾種基本數(shù)據(jù)結(jié)構(gòu)的基本操作。(2)能針對給定題目,選擇相應(yīng)的數(shù)據(jù)結(jié)構(gòu),分析并設(shè)計算法,進(jìn)而給出問題的正確求解過程并編寫代碼實現(xiàn)。 、設(shè)計進(jìn)度及完成情況日 期內(nèi) 容12.31-1.1選取參考書,查閱有關(guān)文獻(xiàn)資料,完成資料搜集和系統(tǒng)分析工作。1.11.2創(chuàng)建相關(guān)數(shù)據(jù)結(jié)構(gòu),錄入

2、源程序。1.21.3調(diào)試程序并記錄調(diào)試中的問題,初步完成課程設(shè)計報告。1.4上交課程設(shè)計報告打印版并進(jìn)行課程設(shè)計答辯,要求每個同學(xué)針對自己的設(shè)計回答指導(dǎo)教師3-4個問題??己私Y(jié)束后將課程設(shè)計報告和源程序的電子版交班長統(tǒng)一刻光盤上交。、主要參考文獻(xiàn)及資料1 嚴(yán)蔚敏 數(shù)據(jù)結(jié)構(gòu)(C語言版)清華大學(xué)出版社 19992 嚴(yán)蔚敏 數(shù)據(jù)結(jié)構(gòu)題集(C語言版)清華大學(xué)出版社 19993 徐寶文等譯 C語言程序設(shè)計 清華大學(xué)出版社4 與所用編程環(huán)境相配套的C語言或C+相關(guān)的資料、成績評定:設(shè)計成績: (教師填寫)指導(dǎo)老師: (簽字)二一一 年 一 月 十 日目 錄第一章 概述1第二章 系統(tǒng)分析2第三章 概要設(shè)計3

3、第四章 詳細(xì)設(shè)計4第五章 運(yùn)行與測試9第六章 總結(jié)與心得13參考文獻(xiàn)14第一章 概述課程設(shè)計是實踐性教學(xué)中的一個重要環(huán)節(jié),它以某一課程為基礎(chǔ),可以涉及和課程相關(guān)的各個方面,是一門獨(dú)立于課程之外的特殊課程。課程設(shè)計是讓同學(xué)們對所學(xué)的課程更全面的學(xué)習(xí)和應(yīng)用,理解和掌握課程的相關(guān)知識。數(shù)據(jù)結(jié)構(gòu)是一門重要的專業(yè)基礎(chǔ)課,是計算機(jī)理論和應(yīng)用的核心基礎(chǔ)課程。數(shù)據(jù)結(jié)構(gòu)課程設(shè)計,要求學(xué)生在數(shù)據(jù)結(jié)構(gòu)的邏輯特性和物理表示、數(shù)據(jù)結(jié)構(gòu)的選擇和應(yīng)用、算法的設(shè)計及其實現(xiàn)等方面,加深對課程基本內(nèi)容的理解。同時,在程序設(shè)計方法以及上機(jī)操作等基本技能和科學(xué)作風(fēng)方面受到比較系統(tǒng)和嚴(yán)格的訓(xùn)練。在這次的課程設(shè)計中我選擇的題目是圖書管理

4、。傳統(tǒng)的人工圖書管理,基本業(yè)務(wù)活動有對一本書的采編入庫、清除庫存、借閱和歸還等等,但是人工統(tǒng)計操作起來效率相對來說要低,也容易出錯。但是現(xiàn)在這些業(yè)務(wù)借助計算機(jī)系統(tǒng)完成后,效率可以得到提高,也可以減少出錯的幾率??梢允箞D書管理的日常業(yè)務(wù)更加的方便,迅捷,減少很多勞動量。課程設(shè)計的目的意義:加深對循環(huán)隊列和數(shù)組的理解,以及對循環(huán)隊列和數(shù)組的實際應(yīng)用,加強(qiáng)自己的動手操作能力,增加對課程的興趣,而不是枯燥的看課本。課程設(shè)計的問題:敢死隊問題 有M個敢死隊員要炸掉敵人的一碉堡,誰都不想去,排長決定用輪回數(shù)數(shù)的辦法來決定哪個戰(zhàn)士去執(zhí)行任務(wù)。如果前一個戰(zhàn)士沒完成任務(wù),則要再派一個戰(zhàn)士上去?,F(xiàn)給每個戰(zhàn)士編一個

5、號,大家圍坐成一圈,隨便從某一個戰(zhàn)士開始計數(shù),當(dāng)數(shù)到5時,對應(yīng)的戰(zhàn)士就去執(zhí)行任務(wù),且此戰(zhàn)士不再參加下一輪計數(shù)。如果此戰(zhàn)士沒完成任務(wù),再從下一個戰(zhàn)士開始數(shù)數(shù),被數(shù)到第5時,此戰(zhàn)士接著去執(zhí)行任務(wù)。以此類推,直到任務(wù)完成為止。 排長是不愿意去的,假設(shè)排長為1號,請你設(shè)計一程序,求出從第幾號戰(zhàn)士開始計數(shù)才能讓排長最后一個留下來而不去執(zhí)行任務(wù)。第二章 系統(tǒng)分析1 敢死隊問題包括:兩個數(shù)據(jù)的輸入,一個是隊員的數(shù)量,另一個是模擬的形式。由于問題給出的數(shù)數(shù)的數(shù)量為5 ,所以k 值就默認(rèn)為5 ,不再設(shè)置數(shù)據(jù)輸入。故重點(diǎn)是要完成兩種數(shù)據(jù)結(jié)構(gòu)形式的刪除,循環(huán)標(biāo)記等操作。2 演示程序是以用戶于計算機(jī)的對話方式執(zhí)行,這

6、需要調(diào)用一個清屏函數(shù)來完成使用者與計算機(jī)語言之間界面的處理。3 程序執(zhí)行時的命令:本程序為了使用時的方便,采用阿拉伯?dāng)?shù)字的方式來完成程序的等各種選擇輸入,幾乎不用輸入什么特殊的命令。(要注意輸入時必須用數(shù)字,否者可能會引起一些死循環(huán))5. 測試數(shù)據(jù)。 1 5 13 數(shù)據(jù)運(yùn)行結(jié)果 在第五章有詳細(xì)的截圖第三章 概要設(shè)計1. 數(shù)據(jù)結(jié)構(gòu)類型: 一種是循環(huán)隊列,另一種是數(shù)組形式 其中循環(huán)隊列操作只需要刪除操作,用數(shù)組形式處理和運(yùn)算上則較復(fù)雜些 因此,循環(huán)隊列占優(yōu)勢2. 程序總體上分為兩大塊,一塊是循環(huán)隊列的模擬,一塊是數(shù)組形式的模擬 這兩種形式功能都是模擬每個開始數(shù)數(shù)的位置對員的死亡順序,其中循環(huán) 隊列

7、的函數(shù)接口為:lianbiao(n) ,數(shù)組的函數(shù)接口為:array(n);兩模塊算法基本一致,數(shù)據(jù)結(jié)構(gòu)形式不同而已算法概述:For(int i=1;i安全的位置; 第四章 詳細(xì)設(shè)計1:存儲結(jié)構(gòu)形式 struct node int data; node *next;struct nodel int data;sqlistN;2:成員函數(shù)部分 int del(node *p,node *q) / 鏈表的刪除操作 while(q-next!=q) int k=4; while(k-) p=p-next; q=q-next; if(q-data=1) return 0; else coutdatan

8、ext; p-next=q; if(q-next=q) return 1; void lianbiao(int n) int i,flag=0; for( i=1;i=n;i+)/ 循環(huán)找出安全的開始位置 int k=i; coutnn報數(shù)的位置為kdata=1; head-next=head; int j=1; while(+jdata=j; p-next=t-next; t-next=p; t=t-next; t=head; node *p=head,*q;/ 設(shè)置p q 指針 while(p-next!=head) p=p-next; q=head; while(-k) /循環(huán)找開始的位

9、置 p=p-next; q=q-next; if(del(p,q)=1) /判斷位置是否安全 coutendli位置安全n; flag=i; else coutendli位置不安全n; continue ; if(flag) coutnn安全位置是: flagnn; else cout所有的位置都不安全13) key-=13; if(sqkey.data!=0) k-; if(key=1) if(sum=1) return 1; else return 0; else sum-=sqkey.data; sqkey.data=0; coutkey13) key-=13; / coutsqkey.

10、data key13) key-=13; / coutsqkey.data keyendl; while(1);void array(int n) int i,flag=0; for( i=1;i=n;i+)/ 循環(huán)找出安全的開始位置 int k=i; coutnn報數(shù)的位置為k時的排長之前的人員死亡順序:n; int j=1,sum=0; while(j = n) /構(gòu)造循環(huán)隊列 sqlistj.data=j; sum+=j+; if( delx(sqlist,k,n,sum)=1) coutendli位置安全n; flag=i;/coutflagendl; else coutendlk位置

11、不安全n; /coutflagendl; cout 所有人員情況: 0 表示已死 其它表示幸存者編號nn; for(int xx=1;xx=n;xx+) coutsqlistxx.data ; coutendl; if(flag) cout安全的位置是:flagnnn; else coutnn無安全位置可選nendl;/ 漏洞檢測3 : 主函數(shù)部分int main() cout-敢死隊之死亡游戲模擬-n; int n,cas; cout作為一名行政長官,報數(shù)開始位置很重要nendl; cout下面將模擬每個開始位置的人員死亡順序-n; /system(cls); do coutcas; if(

12、cas3|cas=0) cout輸入錯誤n;continue; coutn請輸入隊員的數(shù)量n; switch(cas) case 1: lianbiao(n);break; case 2: array(n); break; default : cout輸入錯誤n;break; coutss; if(ss=3) break; else system(cls); while(cas!=3); return 0;第五章 運(yùn)行與測試1. 調(diào)試程序的過程中遇到什么問題 處理過程中經(jīng)常忽視特殊位置的處理 像開始位置為1時,循環(huán)隊列就會出現(xiàn)bugs而數(shù)組形式中刪除操作不容易處理,用0 標(biāo)記來代替 刪除操作,

13、在循環(huán)數(shù)數(shù)的時候經(jīng)常認(rèn)為是5 ,但是 循環(huán)只需要進(jìn)行4 次即可。而刪除操作的判斷則用sum 總和進(jìn)行判斷,替換循環(huán)判斷,省時!操作方便,在4 層循環(huán)數(shù)數(shù)操作中容易漏 data 為0 的判斷以及 對 key 的變相取余3.測試數(shù)據(jù) 1 5 13 第6章 總結(jié)與心得 通過這一課程設(shè)計,加深了我對數(shù)據(jù)結(jié)構(gòu)這門課程所學(xué)內(nèi)容的進(jìn)一步的理解與掌握;同時,通過對循環(huán)隊列和數(shù)組的應(yīng)用,使得我將計算機(jī)課程所學(xué)知識與實際問題很好地相聯(lián)接在了一起。在這次課程設(shè)計中,培養(yǎng)了我開發(fā)一個中小型程序的能力。調(diào)程序的時候,要穩(wěn)扎穩(wěn)打,每個子函數(shù)單調(diào)試后在和主函數(shù)鏈接,效率較高,不然都最后全在一塊,給調(diào)程序會帶來極大的不便!對

14、于每個子函數(shù)都要考慮到一些特殊值。最大的收獲還是感覺到數(shù)據(jù)結(jié)構(gòu)的實用性,不像看課本和考試那樣,總是參生厭煩情緒,離開發(fā)一些東西越來越近了,而不像以前那樣很遙遠(yuǎn)。總之,在這個的課程設(shè)計中,我的收獲還是挺大的,不僅對于專業(yè)課有了更好的認(rèn)識,而且還學(xué)到做事要細(xì)心、全面周到的重要性。參考文獻(xiàn):1 嚴(yán)蔚敏、吳偉民主編 數(shù)據(jù)結(jié)構(gòu)(C語言版) 清華大學(xué)出版社 20022 殷人昆等著 數(shù)據(jù)結(jié)構(gòu)(C+版) 清華大學(xué)出版社 20013 金遠(yuǎn)平著 數(shù)據(jù)結(jié)構(gòu)(C+描述) 清華大學(xué)出版社 2005 4 許卓群等著 數(shù)據(jù)結(jié)構(gòu)與算法 高等教育出版社 20045 Frank M.Carrano 等著 數(shù)據(jù)結(jié)構(gòu)與+高級教程清華大學(xué)出版社 20046 嚴(yán)蔚敏、吳偉民 數(shù)據(jù)結(jié)構(gòu)習(xí)題集(C語言版)清華大學(xué)出版社 14

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

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!