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

付費下載

下載本文檔

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

文檔簡介

信息科學與工程學院課程設計報告班級:通信一班姓名(學號):實驗項目名稱:c語言程序設計實驗室(中心):信息科學與工程學院信息技術實驗室指導教師:李益才實驗完畢時間:2023年6月28日序號項目標準評分1系統(tǒng)演示(功能)(50%)按規(guī)定完畢系統(tǒng)功能且界面和諧容錯能力強(45-50)按規(guī)定完畢系統(tǒng)功能界面一般有較好的容錯能力(40-44)基本完畢系統(tǒng)功能有一定的容錯能力(35-39)基本完畢系統(tǒng)功能(30-34分)未完畢系統(tǒng)功能或別人代做或抄襲(15)2課程設計說明書(50%)課程設計書各項目認真填寫,具有清楚的設計思緒及軟件測試結果分析(45-50)課程設計書各項目認真填寫,具有較為清楚的設計思緒并對軟件測試結果進行了較為清楚的分析(40-44)課程設計書各項目認真填寫,設計思緒對的(35-39)課程設計書進行為較為認真的填寫(30-34)課程設計書有未完畢項或各項填寫不屬實或別人代做或抄襲(15)教師簽字總分一、題目倉庫管理系統(tǒng)二、功能描述該系統(tǒng)將輸入進系統(tǒng)的倉庫中物品的基本信息(涉及貨號、名稱、單價、庫存數(shù)量、品牌)進行解決,可以進行:(1)、按物品價格降序輸出、按庫存數(shù)量升序排列。(2)、修改制定物品的信息。(3)、刪除指定物品的信息。(4)、在指定物品前或后再插入一個物品的信息。(5)、記錄同一種品牌的數(shù)量。三、概要設計系統(tǒng)功能模塊圖進入系統(tǒng)進入系統(tǒng)數(shù)據(jù)按序輸出 數(shù)據(jù)按序輸出 修改特定物品的信息刪除特定物品的信息插入物品信息記錄指定品牌物品的數(shù)量數(shù)據(jù)文獻載入數(shù)據(jù)文獻輸入磁盤物品信息輸入退出系統(tǒng)具體設計1、結構的定義:數(shù)組結構體一共有兩個:鏈表結構體一共有一個:structinformation//物品信息機構structinformation//物品信息機構{{ intArtnumber;intArtnumber; chargoodsname[20];chargoodsname[20]; floatunitprice;floatunitprice;intquantity;intquantity; charbrand[20];charbrand[20];};structinformation*next;structMainfest//倉庫信息機構};{structinformation*head;//頭指針structinformationdata[Number]; intNum;};structMainfestgoods;2、各個函數(shù)的具體設計思想及流程圖本系統(tǒng)一共九個函數(shù):(1)voidinputInformation();//對倉庫中所有物品的基本信息進行輸入(2)voidoutputsort();//按序輸出數(shù)據(jù)(3)voidmodifyInformation();//修改物品信息(4)voiddeleteInformation();//刪除物品信息(5)voidinsertInformation();//插入//插入物品信息(6)voidstatistics();//記錄//記錄相同品牌的物品數(shù)量(7)voidsaveInfoToFile();//文獻輸入到磁盤(8)voidloadInfoFromFile();//文獻磁盤載入(9)voidmaon();//主函數(shù)其中第七、八個為文獻函數(shù),進行文獻的存儲和載入。主函數(shù)main()是一個死循環(huán),每執(zhí)行玩一個函數(shù)都要輸出菜單選擇,直到選擇退出為止。2.1倉庫物品基本信息輸入函數(shù)對物品基本信息進行連續(xù)輸入,直到所有物品信息都輸入完畢,改函數(shù)用while循環(huán)函數(shù)進行連續(xù)賦值。(1)、具體流程圖如下圖所示:開始開始結束已滿,結束break判斷是否已滿結束已滿,結束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()是否結束(2)代碼說明While語句是把數(shù)據(jù)輸入到內(nèi)存中,if這里有兩個用途:1、用于判斷是否尚有空間進行數(shù)據(jù)輸入;2、判斷是否還要繼續(xù)輸入。2.2按序輸出物品信息對物品的特定信息進行排序后在輸出,可以進行按價格降序輸出、按庫存數(shù)量升序輸出,這兩種輸出可以自由選擇數(shù)組開始選擇要排序的元素1、2選擇要排序的元素1、2If(2)按數(shù)量升序if(1)按價格降序If(2)按數(shù)量升序if(1)按價格降序排序sort()排序sort()滿足大小關系進行互換滿足大小關系進行互換輸出,outlist輸出,outlist結束結束鏈表開始選擇排序元素選擇排序元素按價格降序按價格降序輸入sel=1按庫存數(shù)量升序sel=2按庫存數(shù)量升序sel=2Sort(sel)排序Sort(sel)排序Outlist()輸出Outlist()輸出結束結束2.3修改指定物品的信息對數(shù)據(jù)文獻中特定信息驚醒修改,可以修改任何信息開始開始輸入指定物品的信息輸入指定物品的信息printf()查找指定物品i=search(goodsnum)查找指定物品i=search(goodsnum)判斷是否找到指定物品判斷是否找到指定物品找到,對錯誤信息驚醒修改找到,對錯誤信息驚醒修改結束結束鏈表開始開始定義結構體指針,*pf=search(),*pb=pf->next定義結構體指針,*pf=search(),*pb=pf->next輸入要修改的物品貨號printf()輸入要修改的物品貨號printf()判斷是否找到該指定貨品判斷是否找到該指定貨品修改貨品信息Printf()scanf()修改貨品信息Printf()scanf()輸出未找到該貨品結束結束2.4刪除指定貨品信息對磁盤文獻中的特定物品信息進行刪除數(shù)組輸入指定物品的信息輸入指定物品的信息查找指定物品查找指定物品找到,刪除for()找到,刪除for(){a[i-1]=a[i]}if判斷是否找到指定物品if()判斷是否找到指定物品if()goods.Numgoods.Num--;結構體數(shù)目減一結束結束鏈表開始開始定義兩個指向結構體的指針pf=search(goodsn定義兩個指向結構體的指針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)結束結束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];該貨品后每一個元素后移一位插入輸入要插入的物品信息插入輸入要插入的物品信息結束結束鏈表開始開始定義三個指針*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é)點,插入結束結束2.6記錄指定品牌的庫存數(shù)量流程圖數(shù)組開始開始輸入要記錄的品牌名scanf()輸入要記錄的品牌名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);輸出求得的和結束結束鏈表開始structinformation*p;structinformation*p;P=head->next;輸入指定品牌明輸入指定品牌明Scanf(“%s”,name)P!=NULLP!=NULL假如是同一品牌,求和sum=sum+data是假如是同一品牌,求和sum=sum+data輸出和輸出和結束結束2.7、基本數(shù)據(jù)文獻輸入磁盤將輸入的數(shù)據(jù)存儲到磁盤保持。數(shù)組開始開始用fopen()打開一個特定文獻,返回值是否為0用fopen()打開一個特定文獻,返回值是否為0創(chuàng)建這個文獻用fwrite()講數(shù)據(jù)寫入文獻創(chuàng)建這個文獻用fwrite()講數(shù)據(jù)寫入文獻Fclose(fp)關閉文獻Fclose(fp)關閉文獻結束結束鏈表開始開始structinformation*p;structinformation*p;用fopen()打開一個特定文獻,返回值是否為0用fopen()打開一個特定文獻,返回值是否為0建立這個文獻是建立這個文獻打開文獻,并使p=head->next;否打開文獻,并使p=head->next;p!=NULLp!=NULLfclose(fp);fclose(fp);并用while()fwrite()進行循環(huán)輸入否并用while()fwrite()進行循環(huán)輸入結束結束2.8、數(shù)據(jù)文獻載入從磁盤文獻中講已經(jīng)保存了的數(shù)據(jù)讀取到內(nèi)存中,為以后的數(shù)據(jù)解決做準備。開始開始用fopen()打開一個特定文獻,返回值是否為0用fopen()打開一個特定文獻,返回值是否為0是輸出“輸出“該文獻不能被打開”goods.Num==100判斷該文獻是否已滿goods.Num==100判斷該文獻是否已滿是用fread()將文獻讀取出來打印“存儲空間已滿,不能再存入用fread()將文獻讀取出來打印“存儲空間已滿,不能再存入”Feof(fp)=0?判斷文獻是否結束Feof(fp)=0?判斷文獻是否結束Goods.Num++是Goods.Num++Goods.num=100?Goods.num=100?輸出”存儲空間已滿,不能再存儲”是輸出”存儲空間已滿,不能再存儲”用freadj()將文獻讀取出來用freadj()將文獻讀取出來Fclose(fp)Fclose(fp)結束結束鏈表開始開始FILE*fp;str

溫馨提示

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

評論

0/150

提交評論