版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計 紙牌游戲姓名:xxx 學號:xxxx院系:計算機科學與技術(shù)學院 專業(yè):計科 年級:大三 指導老師:xxxx整理為word格式 目 錄 1.課程設(shè)計的目的x2.需求分析x3.課程設(shè)計報告內(nèi)容x 3.1.概要設(shè)計x 3.2.詳細設(shè)計x 3.3.調(diào)試分析x 3.4.用戶手冊x 3.5.測試結(jié)果x 3.6.程序清單x 4.小結(jié)x 5.參考文獻x整理為word格式1.課程設(shè)計的目的(1) 熟練使用 C 語言編寫程序,解決實際問題;(2) 了解并掌握數(shù)據(jù)結(jié)構(gòu)與算法的設(shè)計方法,具備初步的獨立分析和設(shè)計能力;(3) 初步掌握軟件開發(fā)過程的問題分析、系統(tǒng)設(shè)計、程序編碼、測試等基本方法和技能;
2、(4) 提高綜合運用所學的理論知識和方法獨立分析和解決問題的能力;2.需求分析編號為1-52張牌,正面向上,從第2張開始,以2為基數(shù),是2的倍數(shù)的牌翻一次,直到最后一張牌;然后,從第3張開始,以3為基數(shù),是3的倍數(shù)的牌翻一次,直到最后一張牌;直到以52為基數(shù)的翻過,輸出:這時輸出正面向上的牌有哪些?3. 紙牌游戲的設(shè)計3.1概要設(shè)計建立兩個數(shù)組,一個存放52張牌的編號,另外一個存放相應(yīng)編號的紙牌的翻牌記錄:data52,flag52定義一個全局變量作為正反面的判斷條件:Flag= -1Case3:輸出記錄Case2:所有牌翻牌記錄Case1:輸出題目查看翻牌的最后結(jié)果查看指定紙牌翻牌記錄查看所
3、有牌的翻牌記錄查看題目歡迎來到紙牌游戲Case4:顯示最后結(jié)果 開始一維數(shù)組data52,flag52;并將flag初始化為0表示正面朝上整理為word格式Y(jié)YY N N Nj<=52輸出正面朝上的卡牌翻牌。如果flagj-1為0則變?yōu)?,否則變?yōu)? j+ i+ 結(jié)束j%i=0 j=ii<=52 i=23.2詳細設(shè)計整理為word格式/建立兩個數(shù)組,一個存放52張牌的編號,另外一個存放相應(yīng)編號的紙牌的翻牌記錄。int i,j,data52,flag52,choice,num;char m,n;for(i=1;i<=52;i+)datai-1=i;/錄入52張牌的編號。flag
4、i-1=0;/將相應(yīng)編號紙牌的翻牌數(shù)初始化為0。for(i=2;i<=52;i+)/外循環(huán),基數(shù)循環(huán)。for(j=1;j<=52;j+)/內(nèi)循環(huán),基數(shù)倍數(shù)條件判斷。if(j%i=0)dataj-1=dataj-1*Flag;/將翻轉(zhuǎn)后的結(jié)果更新data中的數(shù)據(jù)。 flagj-1+;/翻牌一次,即記入flag數(shù)組中。case 1:printf("-題目-n");printf("*n");printf("編號為1-52張牌,正面向上,從第2張開始,以2為基數(shù),是2的倍數(shù)的牌翻一次,");printf("直到最后一張牌
5、;然后,從第3張開始,以3為基數(shù),是3的倍數(shù)的牌翻一次,");printf("直到最后一張牌;直到以52為基數(shù)的翻過,輸出:這時輸出正面向上的牌有哪些?n");printf("*");printf("n");printf("n");printf("是否回到主菜單?(Y/N):");/在每個獨立功能后添加了獨立的判斷語句,從而可以選擇性的回到主菜單。n=getchar();n=getchar();if(n='Y')break;else if(n='N')c
6、hoice=0;/0作為整個界面的循環(huán)結(jié)束條件,所以直接將choice=0,即可結(jié)束循環(huán)。else printf("*(提示:輸入錯誤,默認為繼續(xù)。)*n"); break;case 2:printf("以下為翻牌記錄:n");printf("t-第1張牌翻過0次。-t");printf("n");整理為word格式printf("n");for(i=1;i<52;i+)printf("t-第%d張牌翻過%d次。-t",i+1,flagi);if(i%2=0)print
7、f("n");printf("n");printf("是否回到主菜單?(Y/N):");n=getchar();n=getchar();if(n='Y')break;else if(n='N')choice=0;else printf("*(提示:輸入錯誤,默認為繼續(xù)。)* *n"); break;case 3:doprintf("t請輸入您想查詢的紙牌編碼:");scanf("%d",&num);if(num<1&&am
8、p;num>52)/紙牌的序號為1-52,所以其他數(shù)值都為輸入錯誤。printf("t輸入錯誤!n");elseprintf("t紙牌翻轉(zhuǎn)記錄如下:n");printf("t紙牌翻轉(zhuǎn)次數(shù)為%dn",flagnum-1);for(j=2;j<=52;j+)/內(nèi)循環(huán),基數(shù)倍數(shù)條件判斷。if(num%j=0)printf("t在以編號%d為基數(shù)時此紙牌有一次翻轉(zhuǎn)。n",j); printf("需要繼續(xù)查詢紙牌編碼嗎?(Y/N):");/獨立的判斷語句,作為do-while的結(jié)束條件,從而可
9、循環(huán)的查詢紙牌編碼。m=getchar();m=getchar();if(m!='Y'&&m!='N')printf("*(提示:輸入錯誤,默認為跳過。)* *n");while(m='Y');printf("是否回到主菜單?(Y/N):");n=getchar();n=getchar();if(n='Y')break;整理為word格式else if(n='N')choice=0;else printf("*(提示:輸入錯誤,默認為繼續(xù)。)* *n
10、");break;case 4:printf("t最后所有正面向上的牌有:n");for(i=0;i<52;i+)if(datai>0)/所有大于0的數(shù)即為正面向上的紙牌。printf(" 第%d張牌 ",i+1);printf("n");printf("是否回到主菜單?(Y/N):");n=getchar();n=getchar();if(n='Y')break;else if(n='N')choice=0;else printf("*(提示:輸入錯
11、誤,默認為繼續(xù)。)* *n");break;case 0:break;default:printf("t輸入錯誤,請重新輸入!n");while(choice!=0);/0作為整個循環(huán)的結(jié)束條件。printf("*程序結(jié)束,謝謝使用*n"); 3.3調(diào)試分析:選擇1,顯示題目整理為word格式選擇2,查看所有翻牌記錄整理為word格式選擇3,查看指定紙牌記錄,如18選擇4,顯示最后結(jié)果整理為word格式4. 程序清單:#include<stdio.h>#include<windows.h>#define Flag -1/
12、定義一個全局變量作為正反面的判斷條件。void main()int i,j,data52,flag52,choice,num;/建立兩個數(shù)組,一個存放52張牌的編號,另外一個存放相應(yīng)編號的紙牌的翻牌記錄。char m,n;for(i=1;i<=52;i+)datai-1=i;/錄入52張牌的編號。flagi-1=0;/將相應(yīng)編號紙牌的翻牌數(shù)初始化為0。for(i=2;i<=52;i+)/外循環(huán),基數(shù)循環(huán)。for(j=1;j<=52;j+)/內(nèi)循環(huán),基數(shù)倍數(shù)條件判斷。if(j%i=0)dataj-1=dataj-1*Flag;/將翻轉(zhuǎn)后的結(jié)果更新data中的數(shù)據(jù)。 flagj-
13、1+;/翻牌一次,即記入flag數(shù)組中。do整理為word格式printf("t-n");printf("t-n");printf("t- 歡迎進入紙牌游戲 -n"); printf("t- 1.查看題目 -n");printf("t- 2.查看所有紙牌的翻牌次數(shù) -n");printf("t- 3.查看指定編號紙牌翻牌記錄 -n"); printf("t- 4.查看最終正面向上的紙牌編號 -n"); printf("t- 0.按0鍵結(jié)束 -n&
14、quot;); printf("t-n");printf("t-n");printf("請輸入您的選擇(數(shù)字0-4):");/主界面scanf("%d",&choice);switch(choice)/通過switch語句進行功能的選擇case 1:printf("-題目-n");printf("*n");printf("編號為1-52張牌,正面向上,從第2張開始,以2為基數(shù),是2的倍數(shù)的牌翻一次,");printf("直到最后一張牌;然
15、后,從第3張開始,以3為基數(shù),是3的倍數(shù)的牌翻一次,");printf("直到最后一張牌;直到以52為基數(shù)的翻過,輸出:這時輸出正面向上的牌有哪些?n");printf("*");printf("n");printf("n");printf("是否回到主菜單?(Y/N):");/在每個獨立功能后添加了獨立的判斷語句,從而可以選擇性的回到主菜單。n=getchar();n=getchar();if(n='Y')break;else if(n='N')cho
16、ice=0;/0作為整個界面的循環(huán)結(jié)束條件,所以直接將choice=0,即可結(jié)束循環(huán)。else printf("*(提示:輸入錯誤,默認為繼續(xù)。)*n"); break;case 2:printf("以下為翻牌記錄:n");printf("t-第1張牌翻過0次。-t");printf("n");printf("n");for(i=1;i<52;i+)printf("t-第%d張牌翻過%d次。-t",i+1,flagi);if(i%2=0)printf("n&q
17、uot;);整理為word格式printf("n");printf("是否回到主菜單?(Y/N):");n=getchar();n=getchar();if(n='Y')break;else if(n='N')choice=0;else printf("*(提示:輸入錯誤,默認為繼續(xù)。)* *n"); break;case 3:doprintf("t請輸入您想查詢的紙牌編碼:");scanf("%d",&num);if(num<1&&
18、num>52)/紙牌的序號為1-52,所以其他數(shù)值都為輸入錯誤。printf("t輸入錯誤!n");elseprintf("t紙牌翻轉(zhuǎn)記錄如下:n");printf("t紙牌翻轉(zhuǎn)次數(shù)為%dn",flagnum-1);for(j=2;j<=52;j+)/內(nèi)循環(huán),基數(shù)倍數(shù)條件判斷。if(num%j=0)printf("t在以編號%d為基數(shù)時此紙牌有一次翻轉(zhuǎn)。n",j); printf("需要繼續(xù)查詢紙牌編碼嗎?(Y/N):");/獨立的判斷語句,作為do-while的結(jié)束條件,從而可循環(huán)的查詢紙牌編碼。m=getchar();m=getchar();if(m!='Y'&&m!='N')printf("*(提示:輸入錯誤,默認為跳過。)* *n");while(m='Y');printf("是否回到主菜單?(Y/N):&qu
溫馨提示
- 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 天津市紅橋區(qū)2025-2026學年高三上學期期末語文試卷(含答案)
- 化工企業(yè)維修工培訓課件
- 化工企業(yè)不安全行為培訓課件
- 化工儀表工培訓課件
- 鋼結(jié)構(gòu)焊后熱處理技術(shù)要點
- 2026年菏澤單縣事業(yè)單位公開招聘初級綜合類崗位人員(26人)備考考試試題及答案解析
- 2026湖南株洲市國資委選聘市屬監(jiān)管企業(yè)專職外部董事考試參考題庫及答案解析
- 2026年度煙臺市福山區(qū)事業(yè)單位公開招聘工作人員(68人)考試備考試題及答案解析
- 2026北京航空航天大學計算機學院聘用編高級研發(fā)工程師F崗招聘1人備考考試題庫及答案解析
- 養(yǎng)生有關(guān)活動策劃方案(3篇)
- 精益生產(chǎn)工作規(guī)劃
- 二級注冊計量師2025年全真模擬測試卷(含答案)
- 2025年廣東中考音樂題庫及答案
- 口腔醫(yī)院會員中心
- 冬季交通安全測試題及答案解析
- 2025年國家能源局系統(tǒng)公務(wù)員面試模擬題及備考指南
- 脊柱感染護理
- 危險品押運證考試題及答案
- 2025年黨建工作應(yīng)試題庫及答案
- 痤瘡皮膚護理常規(guī)
- 2025-2030中國自動分板設(shè)備自動PCB分板設(shè)備行業(yè)運行態(tài)勢與投資前景預(yù)測報告
評論
0/150
提交評論