倉庫管理系統(tǒng)c語言程序設(shè)計報告_第1頁
倉庫管理系統(tǒng)c語言程序設(shè)計報告_第2頁
倉庫管理系統(tǒng)c語言程序設(shè)計報告_第3頁
倉庫管理系統(tǒng)c語言程序設(shè)計報告_第4頁
倉庫管理系統(tǒng)c語言程序設(shè)計報告_第5頁
已閱讀5頁,還剩18頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

1、信息科學(xué)與工程學(xué)院課程設(shè)計報告班 級: 通信一班 姓名 (學(xué)號): 實驗項目名稱: c語言程序設(shè)計 實驗室(中心):信息科學(xué)與工程學(xué)院信息技術(shù)實驗室 指 導(dǎo) 教 師 : 李益才 實驗完成時間: 2013 年 6 月 28 日序號項目標(biāo)準(zhǔn)評分1系統(tǒng)演示(功能)(50%)按要求完成系統(tǒng)功能且界面友好容錯能力強(45-50)按要求完成系統(tǒng)功能界面一般有較好的容錯能力(40-44)基本完成系統(tǒng)功能有一定的容錯能力(35-39)基本完成系統(tǒng)功能(30-34分)未完成系統(tǒng)功能或他人代做或抄襲(15)2課程設(shè)計說明書(50%)課程設(shè)計書各項目認(rèn)真填寫,具有清晰的設(shè)計思路及軟件測試結(jié)果分析(45-50)課程設(shè)

2、計書各項目認(rèn)真填寫,具有較為清晰的設(shè)計思路并對軟件測試結(jié)果進行了較為清晰的分析(40-44)課程設(shè)計書各項目認(rèn)真填寫,設(shè)計思路正確(35-39)課程設(shè)計書進行為較為認(rèn)真的填寫(30-34)課程設(shè)計書有未完成項或各項填寫不屬實或他人代做或抄襲(15)教師簽字總分一、題目 倉庫管理系統(tǒng)二、功能描述該系統(tǒng)將輸入進系統(tǒng)的倉庫中物品的基本信息(包括貨號、名稱、單價、庫存數(shù)量、品牌)進行處理,可以進行:(1)、按物品價格降序輸出、按庫存數(shù)量升序排列。(2)、修改制定物品的信息。(3)、刪除指定物品的信息。(4)、在指定物品前或后再插入一個物品的信息。(5)、統(tǒng)計同一種品牌的數(shù)量。三、概要設(shè)計系統(tǒng)功能模塊圖

3、進入系統(tǒng) 數(shù)據(jù)按序輸出修改特定物品的信息刪除特定物品的信息插入物品信息統(tǒng)計指定品牌物品的數(shù)量數(shù)據(jù)文件載入數(shù)據(jù)文件輸入磁盤物品信息輸入退出系統(tǒng)4、 詳細(xì)設(shè)計 1、結(jié)構(gòu)的定義: 數(shù)組結(jié)構(gòu)體一共有兩個: 鏈表結(jié)構(gòu)體一共有一個:struct information /物品信息機構(gòu) struct information /物品信息機構(gòu) int Artnumber; int Artnumber; char goodsname20; char goodsname20; float unitprice; float unitprice; int quantity; int quantity; char bra

4、nd20; char brand20; ; struct information *next; struct Mainfest /倉庫信息機構(gòu) ; struct information *head; /頭指針 struct information dataNumber;int Num;struct Mainfest goods; 2、各個函數(shù)的具體設(shè)計思想及流程圖本系統(tǒng)一共九個函數(shù):(1)void inputInformation(); /對倉庫中所有物品的基本信息進行輸入(2)void outputsort(); /按序輸出數(shù)據(jù)(3)void modifyInformation(); /修改

5、物品信息(4)void deleteInformation(); /刪除物品信息(5)void insertInformation();/插入 /插入物品信息(6)void statistics();/ 統(tǒng)計 /統(tǒng)計相同品牌的物品數(shù)量(7)void saveInfoToFile(); /文件輸入到磁盤(8)void loadInfoFromFile(); /文件磁盤載入(9)void maon(); /主函數(shù) 其中第七、八個為文件函數(shù),進行文件的存儲和載入。 主函數(shù)main()是一個死循環(huán),每執(zhí)行玩一個函數(shù)都要輸出菜單選擇,直到選擇退出為止。2.1倉庫物品基本信息輸入函數(shù) 對物品基本信息進行連

6、續(xù)輸入,直到所有物品信息都輸入完畢,改函數(shù)用while循環(huán)函數(shù)進行連續(xù)賦值。 (1)、具 體 流 程 圖 如 下 圖 所 示: 開始 結(jié)束 已滿 ,結(jié)束break判斷是否已滿if(goods.Num=Number)未滿,繼續(xù)Printf()scanf()是否要繼續(xù)輸入 if(yn=0)是,繼續(xù)while(1)否,退出break 鏈表 開始 菜單,選擇輸入數(shù)據(jù)函數(shù)head=()malloc();建立一個空節(jié)點head并分配內(nèi)存 temp=()malloc()建立新節(jié)點temp并分配內(nèi)存While(1)循環(huán)t,printf();輸入物品的信息,存入新節(jié)點Temp-next=head-next;He

7、ad-next=temp;判斷是否要繼續(xù)輸入if() 是 否 結(jié)束(2)代碼說明 While語句是把數(shù)據(jù)輸入到內(nèi)存中,if這里有兩個用途:1、用于判斷是否還有空間進行數(shù)據(jù)輸入;2、判斷是否還要繼續(xù)輸入。2.2按序輸出物品信息 對物品的特定信息進行排序后在輸出,可以進行按價格降序輸出、按庫存數(shù)量升序輸出,這兩種輸出可以自由選擇 數(shù)組 開始選擇要排序的元素1、2If(2)按數(shù)量升序if(1)按價格降序排序 sort()滿足大小關(guān)系進行交換輸出,outlist 結(jié)束 鏈表 開始選擇排序元素按價格降序輸入sel=1按庫存數(shù)量升序 sel=2 Sort(sel)排序 Outlist()輸出 結(jié)束 2.3

8、修改指定物品的信息 對數(shù)據(jù)文件中特定信息驚醒修改,可以修改任何信息 開始輸入指定物品的信息printf()查找指定物品i=search(goodsnum)判斷是否找到指定物品找到,對錯誤信息驚醒修改 結(jié)束 鏈表 開始定義結(jié)構(gòu)體指針,*pf=search(),*pb=pf-next輸入要修改的物品貨號printf()判斷是否找到該指定貨物 修改貨物信息Printf()scanf()輸出未找到該貨物 結(jié)束2.4刪除指定貨物信息 對磁盤文件中的特定物品信息進行刪除 數(shù)組輸入指定物品的信息查找指定物品找到,刪除for()ai-1=aiif判斷是否找到指定物品if()goods.Num-;結(jié)構(gòu)體數(shù)目減一

9、 結(jié)束 鏈表 開始定義兩個指向結(jié)構(gòu)體的指針pf=search(goodsnum);pb=pf-next; pf=search(goodsnum); pb=pf-next; pf=search(goodsnum); pb=pf-next;輸入要刪除的貨物貨號scanf()查找指定貨物pf=Search(goodsname)是否找到指定貨物 是 否輸出“未找到指定貨物”刪除pf-next=pb-next;free(pb) 結(jié)束2.5在指定位置插入一個物品的信息(1)流程圖 數(shù)組 開始輸入指定貨物的貨號scanf()是否找到指定貨物選擇前插或者后插if() 前插 后插for(j=goods.Num;

10、ji-1;j-)goods.dataj=goods.dataj-1;該貨物及以后貨物后移一位for(j=goods.Num;ji;j-)goods.dataj=goods.dataj-1;該貨物后每一個元素后移一位插入輸入要插入的物品信息 結(jié)束 鏈表 開始定義三個指針*pf,*pb,*temp找到插入位置Pf=search(goodsnum)Pb=pf-next判斷是否找到指定物品在內(nèi)存中開辟一個空節(jié)點temp=()malloc(()) 是輸入要插入的物品信息scanf(“”,temp-data) 選擇前插還是后插 前插 后插If(pb-next=NULLIf(head=pf) else el

11、setemp-next=pb; pf-next=temp;指定元素為頭節(jié)點后第一個元素,插入temp-next=pb-next;pb-next=temp;指定元素為最后一個節(jié)點,插入 結(jié)束2.6統(tǒng)計指定品牌的庫存數(shù)量(1) 流程圖 數(shù)組 開始 輸入要統(tǒng)計的品牌名scanf() for(i=0;inext;輸入指定品牌明Scanf(“%s”,name) P!=NULL如果是同一品牌,求和sum=sum+data 是 輸出和 結(jié)束2.7、基本數(shù)據(jù)文件輸入磁盤將輸入的數(shù)據(jù)存儲到磁盤保持。 數(shù)組 開始用fopen()打開一個特定文件,返回值是否 為0 創(chuàng)立這個文件用fwrite()講數(shù)據(jù)寫入文件Fcl

12、ose(fp)關(guān)閉文件 結(jié)束 鏈表 開始struct information *p;用fopen()打開一個特定文件,返回值是否 為0 建立這個文件 是打開文件,并使p=head-next; 否 p!=NULL fclose(fp);并用while()fwrite()進行循環(huán)輸入 否 結(jié)束2.8、數(shù)據(jù)文件載入從磁盤文件中講已經(jīng)保存了的數(shù)據(jù)讀取到內(nèi)存中,為以后的數(shù)據(jù)處理做準(zhǔn)備。 開始 數(shù)組 用fopen()打開一個特定文件,返回值是否 為0 是輸出“該文件不能被打開”goods.Num=100判斷該文件是否已滿 是用fread()將文件讀取出來打印“存儲空間已滿,不能再存入” 否Feof(fp)

13、=0?判斷文件是否結(jié)束Goods.Num+ 是Goods.num=100?輸出”存儲空間已滿,不能再存儲” 是 用freadj()將文件讀取出來Fclose(fp) 結(jié)束 鏈表 開始FILE * fp;struct information * p;用fopen()打開一個特定文件,返回值是否 為0P=()malloc()為p分配內(nèi)存打印“文件不能打開”用fread()將文件讀取出來Feof(fp)=0?判斷文件未結(jié)束 否p-next=head-next;head-next=p;P=()malloc(); 是 用fread(0,講文件讀取出來Free(p);Fclose(fp) 結(jié)束5、 測試結(jié)果及存在的問題1、 調(diào)試運行,選擇第一項進行數(shù)據(jù)輸入:2、 按序輸出:(1) 、按物品價格降序輸出(2) 、按庫存數(shù)量升序輸出3、 修改指定物品的信息4、 刪除指定物品的信息5、 在指定物品前或后插入一個物品的信息(1)前插(2)、后插6、求指定品牌的物品數(shù)量不足:修改指定物品的信息和刪除指定物品的信息時,如果有相同貨號的物品,則無法一次性修改和刪除。改進:預(yù)想循環(huán)查找、修改、刪除,直到找不到指定貨物為止。6、 課程設(shè)計心得體會 第一次做這個長度的程序設(shè)計,對我好處很多,在編寫程序的過程中,清楚的找出了自身的不足,以及對課本知識掌握不熟

溫馨提示

  • 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)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論