




已閱讀5頁(yè),還剩2頁(yè)未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
C語(yǔ)言程序設(shè)計(jì)報(bào)告 一 課程設(shè)計(jì)的目的 提高程序設(shè)計(jì)能力,檢驗(yàn)課堂教學(xué)內(nèi)容,掌握程序設(shè)計(jì)的基本方法和調(diào)試技能。二 課程設(shè)計(jì)報(bào)告正文1 課程設(shè)計(jì)題目的原文; 實(shí)驗(yàn)設(shè)備信息包括:設(shè)備編號(hào)、設(shè)備種類(如:微機(jī) 打印機(jī) 掃描儀 等等)、設(shè)備名稱、設(shè)備價(jià)格、設(shè)備購(gòu)入日期、是否報(bào)廢、報(bào)廢日期等。試設(shè)計(jì)一實(shí)驗(yàn)設(shè)備信息管理系統(tǒng),使之能提供以下功能: (1)能夠完成對(duì)設(shè)備的錄入和修改 (2)對(duì)設(shè)備進(jìn)行分類統(tǒng)計(jì) (3)設(shè)備的查詢 2 需求分析 實(shí)驗(yàn)室設(shè)備信息用文件存儲(chǔ),提供文件的輸入輸出操作;要能夠完成設(shè)備的錄入和修改,需要提供設(shè)備添加和修改操作;實(shí)現(xiàn)對(duì)設(shè)備進(jìn)行分類統(tǒng)計(jì),需要提供排序操作;實(shí)現(xiàn)對(duì)設(shè)備查詢需要提供查找操作,設(shè)備的查詢可根據(jù)設(shè)備編號(hào) 設(shè)備種類 設(shè)備購(gòu)入日期 正常設(shè)備(未報(bào)廢的)等多種方式查詢;另外還要根據(jù)鍵盤式選擇菜單以實(shí)現(xiàn)功能選擇。 3總體設(shè)計(jì)與模塊的劃分 整個(gè)系統(tǒng)可設(shè)計(jì)為實(shí)驗(yàn)設(shè)備信息輸入模塊 實(shí)驗(yàn)設(shè)備信息添加模塊 實(shí)驗(yàn)設(shè)備信息修改模塊 實(shí)驗(yàn)設(shè)備分類統(tǒng)計(jì)模塊和實(shí)驗(yàn)設(shè)備查詢模塊。 4 建立實(shí)驗(yàn)設(shè)備信息結(jié)構(gòu)體,結(jié)構(gòu)體成員包括設(shè)備編號(hào) 設(shè)備種類 設(shè)備名稱 設(shè)備價(jià)格 設(shè)備購(gòu)入日期 是否報(bào)廢 報(bào)廢日期。實(shí)驗(yàn)設(shè)備信息輸入模塊實(shí)驗(yàn)設(shè)備信息添加模塊實(shí)驗(yàn)設(shè)備信息修改模塊實(shí)驗(yàn)設(shè)備分內(nèi)統(tǒng)計(jì)模塊實(shí)驗(yàn)設(shè)備查詢模塊功能選擇實(shí)驗(yàn)設(shè)備管理系統(tǒng)設(shè)計(jì)4 詳細(xì)設(shè)計(jì)A 主函數(shù)void main() Node *equip; FILE *fp; int flag; Node *p,*q; printf(tttt設(shè)備管理系統(tǒng)n); equip=(Node*)malloc(sizeof(Node); N結(jié)束根據(jù)n值調(diào)用各功能模塊函數(shù)輸入n,判斷m 是否是0到4?顯示一系列功能選擇開(kāi)始equip-next=NULL; p=equip; fp=fopen(設(shè)備管理系統(tǒng),wb+); q=(Node*)malloc(sizeof(Node); if(fread(q,sizeof(Node),1,fp) /將文件的內(nèi)容放入接點(diǎn)中 q-next=NULL; p-next=q; p=q; /將該接點(diǎn)掛入鏈表中 fclose(fp); /關(guān)閉文件 while(1) printf(*目錄*); printf(n1添加記錄n); printf(n2修改記錄n); printf(n3顯示記錄n); printf(n4統(tǒng)計(jì)分類記錄n); printf(n0*-EXIT-*n); printf(請(qǐng)輸入你要操作的序號(hào):); scanf(%d,&flag); switch(flag) case 0: printf(n提示:已經(jīng)退出系統(tǒng),ByeBye!n);break; case 1: Add(equip); break; /增加記錄 case 2: Modify(equip); break;/修改記錄 case 3: Disp(equip); break;/顯示記錄信息 case 4: Tongji(equip); break;/統(tǒng)計(jì)記錄 default: printf(n提示:輸入錯(cuò)誤!n); break; B 各功能模塊設(shè)計(jì)(1)輸入模塊Struct shebei char ID10; char name15; char kind15; char over15; char yesno10; char time10; char price10; ; (2)追加模塊void Add(Node *equip) /添加記錄 Node *p,*r,*s; char id10; /先用于輸入ID,也用于判斷是否跳出循環(huán) r=equip; s=equip-next; /使s為第一個(gè)有用的結(jié)點(diǎn) while(r-next!=NULL) /這個(gè)循環(huán)的作用是使r為最后一個(gè)有用的結(jié)點(diǎn) 開(kāi)始r=r-next; /將指針置于最末尾 while(1) 輸入ID號(hào),并將指針置于最末尾 printf(提示:輸入0則返回主菜單!n); printf(n請(qǐng)你輸入設(shè)備ID號(hào):); scanf(%s,id); if(strcmp(id,0)=0) break; 依次輸入shebei 結(jié)構(gòu)體內(nèi)容,完成一條添加記錄p=(Node *)malloc(sizeof(Node); /申請(qǐng)空間 strcpy(p-data.ID,id); printf(n請(qǐng)輸入設(shè)備名稱:); scanf(%s,); 提示以完成一條記錄添加printf(n請(qǐng)輸入設(shè)備種類:); scanf(%s,p-data.kind); printf(n請(qǐng)輸入報(bào)廢日期:); scanf(%s,&p-data.over); printf(n請(qǐng)輸入設(shè)備是否報(bào)廢:); 結(jié)束scanf(%s,&p-data.yesno); printf(n請(qǐng)輸入設(shè)備購(gòu)買時(shí)間:); scanf(%s,&p-data.time); printf(n請(qǐng)輸入設(shè)備價(jià)格:); scanf(%s,&p-data.price); printf(提示:已經(jīng)完成一條記錄的添加。n); p-next=NULL; r-next=p; /這一步是必需的,將p與先前的鏈表連起來(lái)構(gòu)成一條新鏈表 r=p; /也是必需的.將r 又重設(shè)為新鏈的最后一個(gè)有用結(jié)點(diǎn) (3)修改模塊void Modify(Node *equip)/修改 Node *p; char find20; if(!equip-next) 開(kāi)始Nprintf(n提示:沒(méi)有資料可以修改!n); return; 判斷是否有內(nèi)容可以修改 printf(請(qǐng)輸入要修改的設(shè)備ID號(hào):); scanf(%s,find); p=equip-next; 沒(méi)有資料可以修改,跳出while(p!=NULL) if(strcmp(p-data.ID,find)=0) /如果找到的話返回的是符合要求 break; 請(qǐng)輸入要修改的設(shè)備ID號(hào)p=p-next; if(p) /若找到 int x; 完成修改輸入0否著輸入任意數(shù)進(jìn)行修改while(1) printf(完成修改請(qǐng)輸入0否則輸入任意數(shù)再進(jìn)行修改:); scanf(%d,&x); 修改成功提示該項(xiàng)記錄資料成功修改if(x=0) break; printf(請(qǐng)輸入新設(shè)備號(hào)(原來(lái)是 %s ):,p-data.ID); scanf(%s,p-data.ID); printf(請(qǐng)輸入新設(shè)備名稱(原來(lái)是 %s ):,); 結(jié)束scanf(%s,); printf(請(qǐng)輸入新設(shè)備設(shè)備種類名稱(原來(lái)是 %s ):,p-data.kind); scanf(%s,p-data.kind); printf(請(qǐng)輸入新設(shè)備報(bào)廢日期名稱(原來(lái)是 %s ):,p-data.over); scanf(%s,p-data.over); printf(請(qǐng)輸入新設(shè)備是否報(bào)廢(原來(lái)是 %s ):,p-data.yesno); scanf(%s,p-data.yesno); printf(請(qǐng)輸入新設(shè)備購(gòu)買時(shí)間(原來(lái)是 %s ):,p-data.kind); scanf(%s,p-data.time); printf(請(qǐng)輸入新設(shè)備價(jià)格(原來(lái)是 %s ):,p-data.price); scanf(%s,p-data.price); printf(n提示:該項(xiàng)記錄資料已經(jīng)成功修改!n); else printf(n提示:你要修改的信息不存在!n); (4)輸出記錄void Disp(Node *equip)/輸出記錄 Node *p; p=equip-next; if(!p) printf(n提示:沒(méi)有記錄可以顯示!n); return; printf(tttt顯示結(jié)果n); printf(設(shè)備號(hào)碼 設(shè)備名稱 設(shè)備種類 報(bào)廢日期 是否報(bào)廢 購(gòu)買時(shí)間 價(jià)格n); while(p) printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-data.ID,,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price); p=p-next; 結(jié)束有記錄者按要求輸出沒(méi)有記錄可以顯示,跳出開(kāi)始(5)統(tǒng)計(jì)模塊void Tongji(Node *equip)/統(tǒng)計(jì) Node *p; int sel;int flag2=0,ha=0; char find20;p=equip-next; if(!equip-next) /若鏈表為空 printf(n提示:沒(méi)有資料可以統(tǒng)計(jì)分類!n); return; printf(提示:n=0退出n=1按設(shè)備號(hào)統(tǒng)計(jì)n=2按設(shè)備名稱統(tǒng)計(jì)n); scanf(%d,&sel); if(sel=1) printf(n輸入你要統(tǒng)計(jì)分類的設(shè)備號(hào):); scanf(%s,find); while(p) if(strcmp(p-data.ID,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(設(shè)備號(hào)碼 設(shè)備名稱 設(shè)備種類 報(bào)廢日期 是否報(bào)廢 購(gòu)買時(shí)間 價(jià)格n); printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-data.ID,,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price); ha=flag2; else if(flag2ha)printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-data.ID,,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price);ha=flag2; p=p-next; if(flag2) printf(n*按設(shè)備號(hào)%s統(tǒng)計(jì)分類的有%d條記錄:*nn,find,flag2); else printf(n按設(shè)備號(hào)%s統(tǒng)計(jì)的結(jié)果為0個(gè)nn,find); else if(sel=2) printf(n輸入你要統(tǒng)計(jì)分類的設(shè)備名稱:); scanf(%s,find); while(p) if(strcmp(,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(設(shè)備號(hào)碼 設(shè)備名稱 設(shè)備種類 報(bào)廢日期 是否報(bào)廢 購(gòu)買時(shí)間 價(jià)格n); printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-data.ID,,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price); ha=flag2; else if(flag2ha)printf(n%-10s%-10s%-10s%-10s
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 船用齒輪箱與傳動(dòng)裝置維修考核試卷
- 電子汽車安全產(chǎn)品考核試卷
- 上海市浦東新區(qū)市級(jí)名校2025年高三年級(jí)月考(三)化學(xué)試題含解析
- 南京師范大學(xué)中北學(xué)院《珠寶玉石概論》2023-2024學(xué)年第二學(xué)期期末試卷
- 武漢航海職業(yè)技術(shù)學(xué)院《遺民文學(xué)研究》2023-2024學(xué)年第一學(xué)期期末試卷
- 內(nèi)蒙古烏海市海勃灣區(qū)2025年初三開(kāi)學(xué)摸底聯(lián)考物理試題含解析
- 濟(jì)南市萊蕪地區(qū)2025年初三第一次模擬考試物理試題文試題含解析
- 金華市金東區(qū)2024-2025學(xué)年五下數(shù)學(xué)期末聯(lián)考模擬試題含答案
- 武夷學(xué)院《發(fā)電廠電氣部分A》2023-2024學(xué)年第二學(xué)期期末試卷
- 武漢學(xué)院《植物病蟲(chóng)害防治》2023-2024學(xué)年第二學(xué)期期末試卷
- 學(xué)會(huì)傾聽(tīng) 養(yǎng)成習(xí)慣
- 循環(huán)流化床鍋爐主要設(shè)備及系統(tǒng)課件
- 扁桃體切除術(shù)與術(shù)后并發(fā)癥
- 防溺水自救施救技能培訓(xùn)內(nèi)容
- GB/T 10561-2023鋼中非金屬夾雜物含量的測(cè)定標(biāo)準(zhǔn)評(píng)級(jí)圖顯微檢驗(yàn)法
- 人工智能技術(shù)在初中英語(yǔ)教學(xué)中的應(yīng)用
- 請(qǐng)假、調(diào)休管理制度
- 市政學(xué)論述題(20題)
- 專業(yè)外語(yǔ)《什么是戰(zhàn)略》翻譯What is strategyMichael Porter
- 水庫(kù)管道輸水工程施工方案優(yōu)秀文檔
- GH/T 1184-2020哈密瓜
評(píng)論
0/150
提交評(píng)論