倉庫管理系統(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頁,還剩19頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

信息科學(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è)計書各項目認(rèn)真填寫,具有較為清晰的設(shè)計思路并對軟件測試結(jié)果進(jìn)行了較為清晰的分析(40-44)課程設(shè)計書各項目認(rèn)真填寫,設(shè)計思路正確(35-39)課程設(shè)計書進(jìn)行為較為認(rèn)真的填寫(30-34)課程設(shè)計書有未完成項或各項填寫不屬實或他人代做或抄襲(15)教師簽字總分一、題目倉庫管理系統(tǒng)二、功能描述該系統(tǒng)將輸入進(jìn)系統(tǒng)的倉庫中物品的基本信息(包括貨號、名稱、單價、庫存數(shù)量、品牌)進(jìn)行處理,可以進(jìn)行:(1)、按物品價格降序輸出、按庫存數(shù)量升序排列。(2)、修改制定物品的信息。(3)、刪除指定物品的信息。1、結(jié)構(gòu)的定義:數(shù)組結(jié)構(gòu)體一共有兩個:鏈表結(jié)構(gòu)體一共有一個:structinformation//物品信息機構(gòu)structinformation//物品信息機構(gòu){{ intArtnumber;intArtnumber; chargoodsname[20];chargoodsname[20]; floatunitprice;floatunitprice;intquantity;intquantity; charbrand[20];charbrand[20];};structinformation*next;structMainfest//倉庫信息機構(gòu)};{structinformation*head;//頭指針structinformationdata[Number]; intNum;};structMainfestgoods;2、各個函數(shù)的具體設(shè)計思想及流程圖本系統(tǒng)一共九個函數(shù):(1)voidinputInformation();//對倉庫中所有物品的基本信息進(jìn)行輸入(2)voidoutputsort();//按序輸出數(shù)據(jù)(3)voidmodifyInformation();//修改物品信息(4)voiddeleteInformation();//刪除物品信息(5)voidinsertInformation();//插入//插入物品信息(6)voidstatistics();//統(tǒng)計//統(tǒng)計相同品牌的物品數(shù)量(7)voidsaveInfoToFile();//文件輸入到磁盤(8)voidloadInfoFromFile();//文件磁盤載入(9)voidmaon();//主函數(shù)其中第七、八個為文件函數(shù),進(jìn)行文件的存儲和載入。主函數(shù)main()是一個死循環(huán),每執(zhí)行玩一個函數(shù)都要輸出菜單選擇,直到選擇退出為止。2.1倉庫物品基本信息輸入函數(shù)對物品基本信息進(jìn)行連續(xù)輸入,直到所有物品信息都輸入完畢,改函數(shù)用while循環(huán)函數(shù)進(jìn)行連續(xù)賦值。(1)、具體流程圖如下圖所示:開始開始結(jié)束已滿,結(jié)束break判斷是否已滿結(jié)束已滿,結(jié)束break判斷是否已滿if(goods.Num==Number)未滿,繼續(xù)Printf()scanf()是否要繼續(xù)輸入if(yn==0)是,繼續(xù)while(1)否,退出break鏈表開始開始菜單,選擇輸入數(shù)據(jù)函數(shù)菜單,選擇輸入數(shù)據(jù)函數(shù)head=()malloc();建立一個空節(jié)點head并分配內(nèi)存head=()malloc();建立一個空節(jié)點head并分配內(nèi)存temp=()malloc()建立新節(jié)點temp并分配內(nèi)存temp=()malloc()建立新節(jié)點temp并分配內(nèi)存While(1)循環(huán)t,printf();輸入物品的信息,存入新節(jié)點While(1)循環(huán)t,printf();輸入物品的信息,存入新節(jié)點Temp->next=head->next;Temp->next=head->next;Head->next=temp;判斷是否要繼續(xù)輸入if()判斷是否要繼續(xù)輸入if()是否結(jié)束(2)代碼說明While語句是把數(shù)據(jù)輸入到內(nèi)存中,if這里有兩個用途:1、用于判斷是否還有空間進(jìn)行數(shù)據(jù)輸入;2、判斷是否還要繼續(xù)輸入。2.2按序輸出物品信息對物品的特定信息進(jìn)行排序后在輸出,可以進(jìn)行按價格降序輸出、按庫存數(shù)量升序輸出,這兩種輸出可以自由選擇數(shù)組開始選擇要排序的元素1、2選擇要排序的元素1、2If(2)按數(shù)量升序if(1)按價格降序If(2)按數(shù)量升序if(1)按價格降序排序sort()排序sort()滿足大小關(guān)系進(jìn)行交換滿足大小關(guān)系進(jìn)行交換輸出,outlist輸出,outlist結(jié)束結(jié)束鏈表開始選擇排序元素選擇排序元素按價格降序按價格降序輸入sel=1按庫存數(shù)量升序sel=2按庫存數(shù)量升序sel=2Sort(sel)排序Sort(sel)排序Outlist()輸出Outlist()輸出結(jié)束結(jié)束2.3修改指定物品的信息對數(shù)據(jù)文件中特定信息驚醒修改,可以修改任何信息開始開始輸入指定物品的信息輸入指定物品的信息printf()查找指定物品i=search(goodsnum)查找指定物品i=search(goodsnum)判斷是否找到指定物品判斷是否找到指定物品找到,對錯誤信息驚醒修改找到,對錯誤信息驚醒修改結(jié)束結(jié)束鏈表開始開始定義結(jié)構(gòu)體指針,*pf=search(),*pb=pf->next定義結(jié)構(gòu)體指針,*pf=search(),*pb=pf->next輸入要修改的物品貨號printf()輸入要修改的物品貨號printf()判斷是否找到該指定貨物判斷是否找到該指定貨物修改貨物信息Printf()scanf()修改貨物信息Printf()scanf()輸出未找到該貨物結(jié)束結(jié)束2.4刪除指定貨物信息對磁盤文件中的特定物品信息進(jìn)行刪除數(shù)組輸入指定物品的信息輸入指定物品的信息查找指定物品查找指定物品找到,刪除for()找到,刪除for(){a[i-1]=a[i]}if判斷是否找到指定物品if()判斷是否找到指定物品if()goods.Numgoods.Num--;結(jié)構(gòu)體數(shù)目減一結(jié)束結(jié)束鏈表開始開始定義兩個指向結(jié)構(gòu)體的指針pf=search(goodsn定義兩個指向結(jié)構(gòu)體的指針pf=search(goodsnum);pb=pf->next;pf=search(goodsnum);pb=pf->next;pf=search(goodsnum);pb=pf->next;輸入要刪除的貨物貨號scanf()輸入要刪除的貨物貨號scanf()查找指定貨物pf=Search查找指定貨物pf=Search(goodsname)是否找到指定貨物是否找到指定貨物是否輸出輸出“未找到指定貨物”刪除pf->next=pb->刪除pf->next=pb->next;free(pb)結(jié)束結(jié)束2.5在指定位置插入一個物品的信息(1)流程圖數(shù)組開始開始輸入指定貨物的貨號scanf()輸入指定貨物的貨號scanf()是否找到指定貨物是否找到指定貨物選擇前插或者后插if()選擇前插或者后插if()前插后插for(j=goods.Num;j>i-1;j--)goods.data[j]=goods.data[j-1];該貨物及以后貨物后移一位for(j=goods.Num;j>i-1;j--)goods.data[j]=goods.data[j-1];該貨物及以后貨物后移一位for(j=goods.Num;j>i;j--)goods.data[j]=goods.data[j-1];該貨物后每一個元素后移一位插入輸入要插入的物品信息插入輸入要插入的物品信息結(jié)束結(jié)束鏈表開始開始定義三個指針*pf,*pb,*temp定義三個指針*pf,*pb,*temp找到插入位置Pf=search(goodsnum)找到插入位置Pf=search(goodsnum)Pb=pf->next判斷是否找到指定物品判斷是否找到指定物品在內(nèi)存中開辟一個空節(jié)點temp=()malloc(())是在內(nèi)存中開辟一個空節(jié)點temp=()malloc(())輸入要插入的物品信息scanf(輸入要插入的物品信息scanf(“”,temp->data)選擇前插還是后插選擇前插還是后插前插后插If(pb->next==NULLIf(head==pf)elseIf(pb->next==NULLIf(head==pf)elsetemp->next=pb;pf->next=temp;指定元素為頭節(jié)點后第一個元素,插入temp->next=pb;pf->next=temp;指定元素為頭節(jié)點后第一個元素,插入temp->next=pb->next;pb->next=temp;指定元素為最后一個節(jié)點,插入temp->next=pb->next;pb->next=temp;指定元素為最后一個節(jié)點,插入結(jié)束結(jié)束2.6統(tǒng)計指定品牌的庫存數(shù)量流程圖數(shù)組開始開始輸入要統(tǒng)計的品牌名scanf()輸入要統(tǒng)計的品牌名scanf()for(i=0;i<goods.Num;i++)for(i=0;i<goods.Num;i++)循環(huán)求和Sun+=quantitySun+=quantityif(i==goods.Num)if(i==goods.Num)i=-1;判斷是否找到品牌的物品i!=-1?判斷是否找到品牌的物品i!=-1?是Printf(“Printf(“為找到該品牌”)printf("%d\n",sum);輸出求得的和結(jié)束結(jié)束鏈表開始structinformation*p;structinformation*p;P=head->next;輸入指定品牌明輸入指定品牌明Scanf(“%s”,name)P!=NULLP!=NULL如果是同一品牌,求和sum=sum+data是如果是同一品牌,求和sum=sum+data輸出和輸出和結(jié)束結(jié)束2.7、基本數(shù)據(jù)文件輸入磁盤將輸入的數(shù)據(jù)存儲到磁盤保持。數(shù)組開始開始用fopen()打開一個特定文件,返回值是否為0用fopen()打開一個特定文件,返回值是否為0創(chuàng)立這個文件用fwrite()講數(shù)據(jù)寫入文件創(chuàng)立這個文件用fwrite()講數(shù)據(jù)寫入文件Fclose(fp)關(guān)閉文件Fclose(fp)關(guān)閉文件結(jié)束結(jié)束鏈表開始開始structinformation*p;structinformation*p;用fopen()打開一個特定文件,返回值是否為0用fopen()打開一個特定文件,返回值是否為0建立這個文件是建立這個文件打開文件,并使p=head->next;否打開文件,并使p=head->next;p!=NULLp!=NULLfclose(fp);fclose(fp);并用while()fwrite()進(jìn)行循環(huán)輸入否并用while()fwrite()進(jìn)行循環(huán)輸入結(jié)束結(jié)束2.8、數(shù)據(jù)文件載入從磁盤文件中講已經(jīng)保存了的數(shù)據(jù)讀取到內(nèi)存中,為以后的數(shù)據(jù)處理做準(zhǔn)備。開始開始用fopen()打開一個特定文件,返回值是否為0用fopen()打開一個特定文件,返回值是否為0是輸出“輸出“該文件不能被打開”goods.Num==100判斷該文件是否已滿goods.Num==100判斷該文件是否已滿是用fread()將文件讀取出來打印“存儲空間已滿,不能再存入用fread()將文件讀取出來打印“存儲空間已滿,不能再存入”Feof(fp)=0?判斷文件是否結(jié)束Feof(fp)=0?判斷文件是否結(jié)束Goods.Num++是Goods.Num++Goods.num=100?Goods.num=100?輸出”存儲空間已滿,不能再存儲”是輸出”存儲空間已滿,不能再存儲”用freadj()將文件讀取出來用freadj()將文件讀取出來Fclose(fp)Fclose(fp)結(jié)束結(jié)束鏈表開始開始FILE*fp;structinformati

溫馨提示

  • 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

提交評論