c語言課程設(shè)計(jì)(圖書管理系統(tǒng))_第1頁
已閱讀1頁,還剩27頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、<p><b>  課程報(bào)告任務(wù)書</b></p><p><b>  成績(jī)?cè)u(píng)定教師: </b></p><p> 題 目圖書信息管理系統(tǒng)</p><p> 主要內(nèi)容開發(fā)一個(gè)圖書信息管理系統(tǒng),圖書信息包括:圖書編號(hào)、書名、作者、出版社、類別、出版時(shí)間、價(jià)格等基本信息(也可以根據(jù)自己情況進(jìn)行擴(kuò)充,比如是否借出、庫

2、存量等)。使之能提供以下基本功能:(1)圖書信息錄入功能(圖書信息用文件保存)--輸入(2)圖書信息瀏覽功能--輸出(3)查詢功能(至少一種查詢方式)、排序功能(至少一種排序方式): ①按書名查詢 ②按作者名查詢 ③ 按照價(jià)錢排序 ④按出版時(shí)間排序等等(4)圖書信息的刪除與修改擴(kuò)展功能:可以按照自己的程度進(jìn)行擴(kuò)展。比如(1)簡(jiǎn)單的權(quán)限處理 (2)報(bào)表打印功能(3)甚至根據(jù)自己情況,可以加上學(xué)生信息,并擴(kuò)充為圖書借閱系統(tǒng)。(4)模糊查詢

3、 (5)綜合查詢 (6)統(tǒng)計(jì)功能 比如統(tǒng)計(jì)處某一類別的圖書信息 或 篩選出小于指定數(shù)量庫存的圖書信息等等,總之,可以根據(jù)自己需求進(jìn)行分析功能。</p><p> 任務(wù)要求一、提交材料應(yīng)包括:(1)系統(tǒng)源代碼 (2)課程報(bào)告二、整個(gè)設(shè)計(jì)過程具體要求(1)需求分析 要求學(xué)生對(duì)案例系統(tǒng)進(jìn)行分析,設(shè)計(jì)出需要完成的功能,完善各個(gè)模塊的調(diào)用關(guān)系;(2)設(shè)計(jì)過程 要求學(xué)生進(jìn)一步明確各模塊調(diào)用關(guān)系,進(jìn)一步完善模塊函數(shù)細(xì)節(jié)

4、(函數(shù)名、參數(shù)、返回值等)(3)實(shí)現(xiàn)過程 要求學(xué)生養(yǎng)成良好的編碼習(xí)慣、完成各個(gè)模塊并進(jìn)行測(cè)試,最終完成系統(tǒng)整體測(cè)試;(4)總結(jié)階段 按照要求完成系統(tǒng)設(shè)計(jì)和實(shí)現(xiàn)報(bào)告,并進(jìn)行總結(jié)、答辯。</p><p> 成績(jī)?cè)u(píng)定報(bào)告撰寫情況(30分)系統(tǒng)完成情況(30分)答辯情況(40分)總分</p><p> 內(nèi)容20分規(guī)范程度5分程序測(cè)試5分基本功能20分?jǐn)U展功能10分自述情況10分答辯情況30

5、分</p><p><b>  1 需求分析</b></p><p>  經(jīng)過大一上學(xué)期的理論學(xué)習(xí),在基礎(chǔ)實(shí)驗(yàn)的基礎(chǔ)上,本學(xué)期我們繼續(xù)開設(shè)了C語言程序設(shè)計(jì)實(shí)踐課。課程要求我們對(duì)已經(jīng)學(xué)習(xí)的基礎(chǔ)實(shí)驗(yàn)進(jìn)行整合與銜接處理,并最終形成一個(gè)系統(tǒng)性質(zhì)的規(guī)模較大的程序。</p><p>  本次課程設(shè)計(jì)要求我們達(dá)到能獨(dú)立完成一個(gè)圖書管理系統(tǒng),完成后要求實(shí)現(xiàn)的功

6、能有對(duì)圖書信息的錄入、刪除、修改,瀏覽(即輸出), 按某種方式查詢(要求至少一種查詢方式),按某種方式排序(要求至少一種排序方式)。當(dāng)然,我們可以根據(jù)自己的能力對(duì)系統(tǒng)進(jìn)行完善性的拓展,例如自己加入簡(jiǎn)單的權(quán)限處理,統(tǒng)計(jì)功能,模糊查詢等,甚至可以拓展為圖書借閱系統(tǒng)。</p><p>  通過整個(gè)程序的開發(fā)過程,最終使我們掌握利用計(jì)算機(jī)解決實(shí)際問題的基本方法,熟悉C語言開發(fā)的全過程,提高綜合應(yīng)用C語言的能力、編程和調(diào)試

7、能力,為學(xué)習(xí)計(jì)算機(jī)和通信專業(yè)的后續(xù)課程打好專業(yè)基礎(chǔ)。 </p><p><b>  2 概要設(shè)計(jì)</b></p><p><b>  圖書信息及數(shù)據(jù)格式</b></p><p><b>  圖書信息:</b></p><p>  圖書信息包括圖書編號(hào)、圖書類別、圖書書名、作者、

8、出版社、出版時(shí)間、圖書價(jià)格。</p><p><b>  數(shù)據(jù)格式:</b></p><p>  本系統(tǒng)采用單向鏈表來對(duì)圖書信息進(jìn)行各項(xiàng)操作。其中圖書的編號(hào)為整型數(shù)據(jù),價(jià)格為雙精度浮點(diǎn)型,其余的類別、書名、作者、出版社與出版時(shí)間均為字符串類型</p><p>  struct tushu_node{</p><p>&l

9、t;b>  int num; </b></p><p>  char leibie[20];</p><p>  char name[30];</p><p>  char author[20];</p><p>  char press[20];</p><p>  char time[20];&l

10、t;/p><p>  double price;</p><p>  struct tushu_node*next;</p><p><b>  };</b></p><p>  一個(gè)結(jié)點(diǎn)的示意圖如下圖所示:</p><p>  (2)程序的整體框架</p><p><b

11、> ?。?)模塊劃分</b></p><p>  1、int quanxian(); 核查權(quán)限的函數(shù) </p><p>  2、int inputchioce(); 顯示主菜單的函數(shù) </p><p>  3、void save();

12、 保存鏈表為文件的函數(shù) 覆蓋以前的信息 </p><p>  4、void save1(); 保存鏈表為文件的函數(shù) 不覆蓋以前的信息 只在創(chuàng)建時(shí)調(diào)用</p><p>  5、struct tushu_node* wjtolb();從文件中讀取數(shù)據(jù)并建立圖書信息的鏈表的函數(shù) </p><p>  6、int luruxinxi();

13、 錄入學(xué)生信息的函數(shù) </p><p>  7、struct tushu_node * luruxinxi_chuangjian(); 創(chuàng)建圖書信息的函數(shù) </p><p>  8、struct tushu_node * luruxinxi_charu(); 插入圖書信息的函數(shù)</p><p>  9、str

14、uct tushu_node * luruxinxi_shanchu(); 刪除圖書信息的函數(shù)</p><p>  10、struct tushu_node * luruxinxi_xiugai(); 修改圖書信息的函數(shù)</p><p>  11、int liulantushu(); 瀏覽

15、圖書信息的函數(shù) </p><p>  12、int chaxuntushu(); 查詢圖書信息的函數(shù) </p><p>  13、void chaxuntushu_num(); 按編號(hào)查詢圖書 </p><p>  14、void chaxuntush

16、u_name(); 按書名查詢圖書 </p><p>  15、void chaxuntushu_price(); 按價(jià)格查詢圖書 </p><p>  16、void paixutushu(); 為圖書排序的函數(shù) </p&

17、gt;<p>  17、struct tushu_node* paixutushu_price(); 為圖書按價(jià)格排序的函數(shù) </p><p>  18、struct tushu_node* paixutushu_time(); 為圖書按出版時(shí)間排序的函數(shù) </p><p>  19、void sfjx() ;

18、 寫個(gè)函數(shù) 判斷是否繼續(xù) 排序中使用 </p><p>  20、int tongjitushu_shumu(); 統(tǒng)計(jì)圖書數(shù)目的函數(shù) </p><p>  21、void shiyongshuoming(); 使用說明的函數(shù) </p><p>

19、;<b>  3 詳細(xì)設(shè)計(jì)</b></p><p>  程序的主體設(shè)計(jì)思想是根據(jù)結(jié)構(gòu)化程序設(shè)計(jì)思想分模塊進(jìn)行設(shè)計(jì),有一個(gè)主函數(shù)和多個(gè)自定義函數(shù)構(gòu)成。</p><p><b>  主函數(shù)</b></p><p>  對(duì)于本程序來說,主函數(shù)很簡(jiǎn)單,就是定義了一個(gè)變量chioce用來接受核查用戶是否有使用該管理系統(tǒng)的權(quán)限的函數(shù)q

20、uanxian()函數(shù)返回的值,若為1(即用戶獲得了使用權(quán)限),則調(diào)出顯示主菜單的函數(shù)進(jìn)行具體操作</p><p>  int main()</p><p><b>  {</b></p><p>  int chioce; </p><p>  chioce=quanxian(); 核查用戶是

21、否有使用該管理系統(tǒng)的權(quán)限的函數(shù)</p><p>  if(chioce==1) 若取得權(quán)限 則返回值為1 </p><p><b>  {</b></p><p>  system("cls");</p><p>  inputchioce(); 用

22、來顯示主菜單的函數(shù)</p><p><b>  }</b></p><p><b>  exit(0);</b></p><p><b>  }</b></p><p><b>  權(quán)限函數(shù)</b></p><p>  核查用戶權(quán)限

23、的函數(shù)使用do-while語句來限制用戶輸入密碼的次數(shù)僅為三次,并且為了使界面更具親切感,會(huì)在用戶輸入密碼錯(cuò)誤時(shí)進(jìn)行提示引起用戶注意及提示剩余輸入次數(shù)。</p><p>  int quanxian()</p><p><b>  {</b></p><p>  int m=1,n=3,flag=0;</p><p> 

24、 char mima[20];</p><p><b>  do{</b></p><p>  printf("\n\n 你好,歡迎使本圖書信息管理系統(tǒng)!\n"); printf("\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

25、~~\n");</p><p>  printf("【現(xiàn)在進(jìn)行權(quán)限核查】 \n--------------------友情提醒:你共有3次輸入密碼的機(jī)會(huì)!\n");</p><p>  printf("\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n ");&

26、lt;/p><p>  if(n==2||n==1){printf("注意:你已輸入錯(cuò)誤%d次 剩余輸入次數(shù): %d 請(qǐng)輸入密碼:",3-n,n);}</p><p>  if(n==3) printf("剩余輸入次數(shù): %d 請(qǐng)輸入密碼:",n);</p><p>  scanf("%s",m

27、ima); //第一次輸入和輸錯(cuò)密碼后再次輸入顯示的也賣弄不同</p><p>  if(strcmp(mima,"chenbo0916")==0)</p><p><b>  {</b></p><p><b>  flag=1;</b></p><p>  return

28、flag;</p><p><b>  } </b></p><p><b>  m++;</b></p><p><b>  n--;</b></p><p>  system("cls");</p><p>  }w

29、hile(strcmp(mima,"chenbo0916")!=0&&m<=3) ; // 限制輸入次數(shù)在3次之內(nèi)</p><p>  printf("\n\n對(duì)不起,你連續(xù)三次輸入密碼錯(cuò)誤,沒有使用該圖書管理系統(tǒng)的權(quán)限!\n");</p><p>  exit(0); </p><p><b

30、>  }</b></p><p><b>  顯示主菜單的函數(shù)</b></p><p>  本程序?qū)⒅鞑藛螁为?dú)作為一個(gè)函數(shù)是為了讓用戶進(jìn)入一次系統(tǒng)可以進(jìn)行多項(xiàng)操作(即為在每次用戶完成一個(gè)具體的操作后,都會(huì)有對(duì)是否繼續(xù)或返回主菜單有相應(yīng)的詢問,讓用戶在想退出系統(tǒng)時(shí)才退出),基本思路是通過函數(shù)的嵌套調(diào)用來實(shí)現(xiàn)多項(xiàng)操作。這個(gè)函數(shù)的功能就是顯示主菜單并對(duì)用戶

31、進(jìn)行的選擇調(diào)用不同的子菜單函數(shù)或進(jìn)入具體功能</p><p>  int inputchioce() /* 主菜單 */</p><p><b>  {</b></p><p>  int mychioce,x=-1;</p><p>

32、;  printf("\n++++++++++++++歡 迎 你++++++++++++++++++\n\n");</p><p>  printf("**+++++++++++++ 主 菜 單 +++++++++++++++++++++**\n");</p><p>  printf("**1-- 錄入(刪除 修改)圖書信息 ** **2

33、--(按規(guī)則)查詢圖書信息 **\n");</p><p>  printf("** 3-- 瀏覽圖書信息**** 4-- 為圖書(按規(guī)則)排序 **\n");</p><p>  printf("** 5-- 統(tǒng)計(jì)圖書(數(shù)目) **** 6-- 幫助 **\n");</p>&

34、lt;p>  printf("** 0-- 退出系統(tǒng) ** ** **\n"); printf("**++++++++++++++++++++++++++++++++++++++++++++++++++++++++**\n");</p><p>  printf("\n 恭喜你獲得使用權(quán)限

35、,請(qǐng)你選擇:");</p><p>  scanf("%d",&mychioce);</p><p>  switch(mychioce) </p><p><b>  {</b></p><p><b>  case 1:</b></p&

36、gt;<p>  {luruxinxi();break;}</p><p><b>  case 2:</b></p><p>  { chaxuntushu();break;}</p><p><b>  case 3:</b></p><p>  {liulantushu()

37、;break;}</p><p><b>  case 4:</b></p><p>  {paixutushu();break;}</p><p><b>  case 5:</b></p><p>  { tongjitushu_shumu();</p><p> 

38、 printf("\n\n是否繼續(xù)操作? 請(qǐng)選擇(繼續(xù)-1/退出-0)");</p><p>  scanf("%d",&x);</p><p>  if(x==1){system("cls");inputchioce();}</p><p><b>  if(x==0){</b&

39、gt;</p><p>  printf("\n\n謝謝你的使用! 再見\n");</p><p>  exit (0); </p><p><b>  }</b></p><p>  if(x!=1&&x!=0){</p><p>  system(&quo

40、t;cls"); </p><p>  printf("選擇有誤,默認(rèn)返回主菜單,請(qǐng)重新選擇:\n");</p><p>  inputchioce();}</p><p><b>  break;</b></p><p><b>  }</b></p>

41、<p><b>  case 6:</b></p><p>  {shiyongshuoming();break;}</p><p><b>  case 0:</b></p><p>  { printf(" \n\n 謝謝你的使用?。≡僖?\n\n");break;}

42、 </p><p><b>  default:</b></p><p>  { system("cls");</p><p>  printf("\n 選擇有誤,請(qǐng)重新選擇:\n");</p><p>  inputchioce();

43、</p><p><b>  }break;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  關(guān)于一些錄入(刪除 修改)、查詢、排序等子菜單的原理及實(shí)現(xiàn)方法與主菜單那類似</p><p>&l

44、t;b>  創(chuàng)建(插入)函數(shù)</b></p><p><b>  算法如下圖:</b></p><p>  結(jié)束輸入控制條件Num!=0</p><p>  將鏈表數(shù)據(jù)保存為文件的函數(shù)</p><p>  首先打開文件以可讀寫(也可以只寫的方式打開 區(qū)別在于是否覆蓋以前的信息)的方式,p1作為形參來接受

45、實(shí)參head,只要不為空,寫入p1 后,下移一個(gè)節(jié)點(diǎn)</p><p>  void save1(struct tushu_node* p1){ /*將鏈表保存為文件的函數(shù) 不覆蓋前面信息 */</p><p>  if( (fpp=fopen("1.txt","a"))==NULL )</p><p><b>  

46、{</b></p><p>  printf("打開文件失敗!");</p><p><b>  exit(0);</b></p><p><b>  }</b></p><p>  while(p1!=NULL)</p><p><b&

47、gt;  { </b></p><p>  fprintf(fpp," %d %s %s %s %s %s %lf\n",p1->num,p1->leibie,p1-> </p><p>  name,p1->author,p1->press,p1->time,p1->price);

48、 </p><p>  p1=p1->next;</p><p><b>  }</b></p><p>  if(fclose(fpp))</p><p><b>  { </b></p><p>  printf("關(guān)閉文件失?。n");

49、</p><p><b>  exit(0);</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  從文件中讀出數(shù)據(jù)并創(chuàng)建鏈表的函數(shù)</p><p>  在調(diào)用從文件讀取數(shù)據(jù)創(chuàng)建鏈表的函數(shù)前,先定義

50、head鏈表指針并賦值為空作為實(shí)參 。打開文件后,從文件中讀取一組數(shù)據(jù)賦給已經(jīng)被動(dòng)態(tài)分配內(nèi)存的結(jié)點(diǎn)指針p</p><p>  第一次head為空時(shí)</p><p><b>  Head</b></p><p><b>  p1</b></p><p>  第二次以后head

51、 head</p><p>  p2 p1</p><p><b>  head</b></p><p>  p2 p1</p><p><b>  刪除函數(shù) </b></p><p>  

52、刪除函數(shù)執(zhí)行流程圖及算法如下圖所示:</p><p><b>  Head=NULL</b></p><p>  Head!=NULL</p><p>  相等(即刪除頭結(jié)點(diǎn))</p><p>  不相等(刪除其他結(jié)點(diǎn))</p><p>  Ptr2!=NULL (即不是鏈表結(jié)尾 循環(huán)結(jié)束

53、條件)</p><p>  While循環(huán) 相等</p><p><b>  不相等</b></p><p><b>  修改函數(shù)</b></p><p>  修改函數(shù)執(zhí)行流程圖如下:</p><p>  If (Head!=Nul

54、l)</p><p><b>  不相等</b></p><p><b>  相等</b></p><p>  是 否</p><p><b>  瀏覽遍歷函數(shù)</b></p><p>  重新定義一組變量num、le

55、ibie、name、author、press、time、 price,將從文件中讀取一組數(shù)據(jù)后賦給這組變量并輸出它們,使用while(!feof(fp)),一直執(zhí)行上述過程實(shí)現(xiàn)遍歷瀏覽全部文件中的圖書信息。瀏覽完成后,同樣有對(duì)是否繼續(xù)其他操作的詢問,如果選擇繼續(xù),則會(huì)返回主菜單。</p><p>  int liulantushu() /* 瀏覽圖書信息的函數(shù) */ </p>

56、<p>  {int num; </p><p>  char leibie[10];</p><p>  char name[30];</p><p>  char author[20];</p><p>  char press[20];</p><p>  char time[20];</p&

57、gt;<p>  double price;</p><p>  int x=-1;</p><p>  if( (fpp=fopen("1.txt","r"))==NULL )</p><p><b>  {</b></p><p>  printf("

58、 打開文件失敗 ! ");</p><p><b>  exit(0);}</b></p><p><b>  else{</b></p><p>  printf("\n\n編號(hào) 類別 書名 作者 出版社 出版時(shí)間 價(jià)格\n");</p><p>  

59、while(!feof(fpp)){ fscanf(fpp,"%d%s%s%s%s%s%lf",&num,leibie,name,autho </p><p>  r,press,time,&price); printf("%d %s %s %s %s %s %lf\n ",num,leibie,name

60、,author,press,time,price);}</p><p><b>  }</b></p><p>  if(fclose(fpp))</p><p>  {printf("關(guān)閉文件失敗!\n");</p><p><b>  exit(0);</b></p

61、><p><b>  }</b></p><p>  printf("\n\n是否繼續(xù)操作? 請(qǐng)選擇(繼續(xù)-1/退出-0)");</p><p>  scanf("%d",&x);</p><p><b>  if(x==1)</b></p>

62、<p>  { system("cls");</p><p>  inputchioce();}</p><p><b>  if(x==0)</b></p><p>  { printf("\n\n謝謝你的使用! 再見\n");</p><p>  exit

63、 (0);}</p><p>  if(x!=1&&x!=0)</p><p>  { system("cls"); </p><p>  printf("選擇有誤,默認(rèn)返回主菜單,請(qǐng)重新選擇:\n");</p><p>  inputchioce();}</p>&l

64、t;p><b>  }</b></p><p><b>  統(tǒng)計(jì)圖書數(shù)目的函數(shù)</b></p><p>  統(tǒng)計(jì)函數(shù)簡(jiǎn)單的實(shí)現(xiàn)了對(duì)圖書數(shù)目的統(tǒng)計(jì),其實(shí)現(xiàn)思路可以看做在瀏覽函數(shù)的基礎(chǔ)上去掉一些不必要的輸出而是另外加上一個(gè)變量n用在while中執(zhí)行一次循環(huán)就n++一次,就能統(tǒng)計(jì)出圖書的數(shù)目了,不再具體敘述。由于feof()函數(shù)本身的原理,如果每

65、次寫入一行數(shù)據(jù)到文件中時(shí)最后有換行符號(hào),則會(huì)出現(xiàn)n多加一問題或輸出時(shí)最后一行復(fù)制,只要將n減一即為圖書實(shí)際上的數(shù)目。</p><p><b>  查詢函數(shù)</b></p><p>  查詢函數(shù)算法如下圖所示:</p><p><b>  P!=NULL</b></p><p><b>  

66、不相等</b></p><p><b>  相等</b></p><p>  如果found依然為0 ,則輸出“未找到某圖書”</p><p>  是 否</p><p><b>  排序函數(shù)</b></p><p>

67、  排序函數(shù)算法敘述如下:</p><p>  排序函數(shù)使用冒泡排序的算法,定義了i j兩個(gè)變量來控制實(shí)現(xiàn)雙層循環(huán),for(i=1;i<n;i++)(n為調(diào)用統(tǒng)計(jì)函數(shù)統(tǒng)計(jì)的圖書總數(shù)目)來實(shí)現(xiàn)外循環(huán),一次外循環(huán)將鏈表中價(jià)格最高的(或出版時(shí)間最靠后的)圖書移動(dòng)至鏈表的最后,具體實(shí)現(xiàn)過程(即內(nèi)循環(huán))如下圖所示:</p><p><b>  內(nèi)循環(huán):</b></p

68、><p><b>  初始化狀態(tài)為</b></p><p>  P4 P4->next</p><p>  輔助 P3 p1 p2</p><p>  比較p1與p2的排序項(xiàng),如p1比 p2小,上圖所有指針的指針均后移一位</p><p>  相反

69、 ,若上圖中p1比 p2大,則變?yōu)?lt;/p><p>  P3 P3->next</p><p>  P2->next p1 p2</p><p>  簡(jiǎn)單的說———始終是p1與p2比較,其中一個(gè)為前一次比較中的的大的一個(gè),另一個(gè)向后移動(dòng)</p><p><b&

70、gt;  內(nèi)循環(huán)源程序</b></p><p>  p4=(struct tushu_node*)malloc(size);</p><p>  p4->next=head; </p><p><b>  p3=p4;</b></p><p><b>  p1=head;</b>&

71、lt;/p><p>  p2=head->next;</p><p>  for(j=0;j<n-i;j++)</p><p><b>  {</b></p><p>  if(p2->price>p1->price)</p><p><b>  {</b

72、></p><p><b>  p3=p1;</b></p><p><b>  p1=p2;</b></p><p>  p2=p2->next;</p><p><b>  }</b></p><p><b>  else<

73、;/b></p><p><b>  {</b></p><p>  p1->next =NULL;</p><p>  p1->next=p2->next;</p><p>  p3->next=p2;</p><p>  p2->next =p1;</

74、p><p><b>  p3=p2;</b></p><p>  p2=p1->next;</p><p><b>  }</b></p><p><b>  }</b></p><p>  head=p4->next;free(p4);<

75、/p><p><b>  4 調(diào)試分析</b></p><p>  程序的編寫過程中調(diào)試時(shí)遇到的問題及如何解決:</p><p>  問題一 界面不美觀,進(jìn)入一次系統(tǒng)只能進(jìn)行一項(xiàng)操作的問題</p><p>  解決方法 通過將主菜單的顯示作為一個(gè)獨(dú)立的函數(shù)(inputchoice()),結(jié)合函數(shù)的嵌套調(diào)用實(shí)現(xiàn),與清屏函數(shù)

76、(system(“cls”))一起,在每次進(jìn)行完一次具體操作都有以下詢問</p><p>  printf("\n\n是否繼續(xù)操作? 請(qǐng)選擇(繼續(xù)-1/退出-0)");</p><p>  scanf("%d",&x);</p><p><b>  if(x==1)</b></p>

77、<p><b>  {</b></p><p>  system("cls");</p><p>  inputchioce();</p><p><b>  }</b></p><p><b>  if(x==0)</b></p>

78、<p><b>  {</b></p><p>  printf("\n\n謝謝你的使用! 再見\n");</p><p>  exit (0); </p><p><b>  }</b></p><p>  if(x!=1&&x!=0)</p&

79、gt;<p><b>  {</b></p><p>  system("cls"); </p><p>  printf("選擇有誤,默認(rèn)返回主菜單,請(qǐng)重新選擇:\n");</p><p>  inputchioce();</p><p><b>  }&

80、lt;/b></p><p>  實(shí)現(xiàn)了每次操作完成后,使只顯示主菜單可繼續(xù)進(jìn)行其他操作</p><p>  問題二 權(quán)限系統(tǒng)以前是輸入學(xué)號(hào)后三位(int)進(jìn)行驗(yàn)證并且只有一次輸入機(jī)會(huì),一次輸入錯(cuò)誤就退出系統(tǒng)</p><p>  解決方法 在權(quán)限函數(shù)中使用字符串變量(char)來作為密碼,使用do-while語句來實(shí)現(xiàn)對(duì)輸入次數(shù)的控制</p>

81、<p>  問題三 錄入時(shí)以前的思路是想在輸入的同時(shí)寫入文件只有一組數(shù)據(jù)想存入文件</p><p>  解決方法 將保存文件作為一個(gè)獨(dú)立的函數(shù)。在創(chuàng)建函數(shù)中有一組另外的參數(shù)來接收用戶輸入的數(shù)據(jù),然后再調(diào)用保存函數(shù)將數(shù)據(jù)存入文件</p><p>  問題四 文件的保存與讀取問題</p><p>  解決方法 由于系統(tǒng)要求結(jié)合文件的知識(shí)使用戶的數(shù)據(jù)

82、在一次輸入之后即使關(guān)閉退出系統(tǒng)后在次進(jìn)入系統(tǒng)時(shí)原有數(shù)據(jù)依然能繼續(xù)使用。并且在對(duì)數(shù)據(jù)進(jìn)行創(chuàng)建、刪除、修改、排序等相關(guān)的操作之后要重新保存,所以將將鏈表保存到文件和從文件讀取數(shù)據(jù)建立鏈表都重新寫作單獨(dú)的函數(shù),在進(jìn)行完相關(guān)的操作后都調(diào)用save()重新保存,在再次進(jìn)行操作前就先調(diào)用wjtolb()函數(shù)從文件中讀取數(shù)據(jù)創(chuàng)建鏈表,實(shí)現(xiàn)了對(duì)數(shù)據(jù)更及時(shí)的保存與利用</p><p>  問題五 保存數(shù)據(jù)時(shí)覆蓋不覆蓋原有數(shù)據(jù)的問

83、題</p><p>  解決問題 由于以前沒有注意細(xì)節(jié)問題導(dǎo)致雖然數(shù)據(jù)被修改或是刪除后保存成功,但數(shù)據(jù)不覆蓋原來的數(shù)據(jù)從而出現(xiàn)文件中數(shù)據(jù)重復(fù)保存的問題,解決方法很簡(jiǎn)單,只要將打開文件的方式由可讀可寫(a)改為只寫方式打開(w)就行</p><p>  問題六 輸入時(shí)無法結(jié)束輸入的問題</p><p>  解決方法 由于在輸入時(shí)時(shí)先輸入圖書的編號(hào),所以在輸入時(shí)除了輸

84、入第一本圖書的信息,</p><p>  即在輸入第一本圖書之后在輸入時(shí)先輸入圖書的編號(hào),加上一個(gè)判斷循環(huán)while(num!=0)才繼續(xù)輸入完這本圖書的其他信息,即0可以作為輸入結(jié)束標(biāo)志</p><p>  問題七 程序漏洞,只有第二本圖書信息無法修改的問題</p><p>  解決方法 程序設(shè)計(jì)思路有問題及對(duì)do-while語句了解不充分導(dǎo)致了問題。修改函數(shù)

85、的思路是先讓用戶先輸入要修改的圖書編號(hào)再依次查詢,先看頭結(jié)點(diǎn)的圖書編號(hào)與要修改的編號(hào)是否相等,如果相等繼續(xù)選擇要修改的圖書信息成分修改,如果不相等,有個(gè)循環(huán)語句來使結(jié)點(diǎn)后移只帶相等再選擇要修改的圖書信息成分修改。有問題的寫法是使用了</p><p><b>  do {</b></p><p>  p=p->next;</p><p>

86、;  } while(p!=NULL&&p->num!=numm) </p><p>  從而導(dǎo)致了如果要修改的圖書不是第一本而是第二本時(shí),先執(zhí)行了后移一個(gè)結(jié)點(diǎn)直接到第三個(gè)結(jié)點(diǎn)即無法修改第二本圖書的信息。解決后是用while循環(huán)</p><p>  while(p!=NULL&&p->num!=numm)</p><p>

87、<b>  {</b></p><p>  p=p->next;</p><p><b>  }</b></p><p><b>  就不存在上述問題</b></p><p>  問題八 要對(duì)圖書的信息進(jìn)行刪除后修改前必須先瀏覽圖書不然不知道要選擇哪本圖書進(jìn)行操作的問題

88、</p><p>  解決方法 由于上述修改與刪除的操作是通過用戶對(duì)圖書編號(hào)的選擇來完成的所以在瀏覽前不知道圖書對(duì)于的編號(hào)就使操作具有盲目性即對(duì)圖書的信息進(jìn)行刪除后修改前必須先瀏覽圖書。解決時(shí)時(shí)讓修改于刪除函數(shù)中讓用戶輸入編號(hào)前默認(rèn)直接輸出所有圖書(遍歷所有圖書)</p><p><b>  5測(cè)試結(jié)果 </b></p><p>  編號(hào) 類

89、別 書名 作者 出版社 出版時(shí)間 價(jià)格</p><p>  4 傳記 讓世界因你而不同 李開復(fù) 北京工業(yè)出版社 2008.3 28.000000 </p><p>  2 英語 四級(jí)詞匯 俞敏洪 群言出版社 2008.9 32.000000 </p>

90、<p>  5 漫畫 我兔斯基你 王卯卯 動(dòng)漫出版社 2009.3 32.000000 </p><p>  3 營(yíng)銷 哈佛市場(chǎng)營(yíng)銷策略 宋海峰 內(nèi)蒙古出版社 2010.4 28.000000 </p><p>  1 雜志 電腦愛好者 無 cfan雜志社 2010.9

91、 6.000000 </p><p>  6 教材 思修 羅國(guó)杰 高等教育出版社 2006.8 15.50</p><p>  7 教材 大學(xué)英語 王大偉 外研社 2005.1 34.9</p><p>  8 教材 高等數(shù)學(xué) 蔣青

92、 高等教育出版社 2007.6 25.9</p><p>  現(xiàn)在給出一組測(cè)試數(shù)據(jù)來全程展示本圖書管理系統(tǒng)的所有功能 </p><p>  功能一之核查用戶權(quán)限:</p><p>  首先進(jìn)入系統(tǒng),你會(huì)發(fā)現(xiàn)要求對(duì)用戶使用權(quán)限進(jìn)行核查的界面:(效果圖如下)</p><p>  若密碼為錯(cuò)誤密碼,那么你會(huì)看到提醒“注意”的界面</p&

93、gt;<p>  上圖密碼正確,則仍然可以順利進(jìn)入系統(tǒng)見到主菜單 如下圖</p><p>  若三次輸入錯(cuò)誤 將無法進(jìn)入系統(tǒng)</p><p>  功能二之瀏覽全部圖書:</p><p>  在主菜單界面選擇3則可遍歷現(xiàn)有全部圖書信息</p><p>  功能三之創(chuàng)建或添加圖書:</p><p>  選擇

94、1后進(jìn)入錄入(刪除 修改)子菜單</p><p>  繼續(xù)選擇1進(jìn)入創(chuàng)建添加圖書功能 以0結(jié)束輸入</p><p>  結(jié)束后自動(dòng)返回主菜單 再次選擇3(瀏覽)可查看添加效果(瀏覽時(shí)剛才上圖添加的圖書信息“9 IT FLASH8 尹浩瓊 電子工業(yè)出版社 2006.9 41”顯示在最后一行說明程序已經(jīng)實(shí)現(xiàn)了添加功能)</p><p>  功能四之為圖書按規(guī)則排序:&

95、lt;/p><p>  選擇4后進(jìn)入排序子菜單進(jìn)一步選擇按何種規(guī)則排序(報(bào)告只演示按出版時(shí)間排序)</p><p>  當(dāng)選擇2—按出版時(shí)間排序 然后回車鍵你會(huì)看到</p><p>  選1繼續(xù)返回瀏覽看到圖書已經(jīng)按出版時(shí)間的先后排序完成</p><p>  功能五之按規(guī)則查詢圖書:</p><p>  同排序一樣你可以

96、在子菜單選擇按何種方式查詢(報(bào)告只演示按書名查詢)</p><p>  選擇按書名查詢后你可以輸入書名</p><p>  查詢圖書《當(dāng)代大學(xué)生》的結(jié)果是“沒有找到這本書”</p><p>  選擇1繼續(xù)按書名查找其他圖書</p><p>  查找到圖書《讓世界因你而不同》時(shí),這本圖書的信息將被全部輸出,如圖:</p><

97、p>  功能六之修改已有圖書信息:</p><p>  從錄入子菜單1進(jìn)入后選擇3可以進(jìn)入修改功能 首先你會(huì)看到目前文件中所有圖書的信息方便你選擇要修改哪本圖書</p><p>  上圖選擇了修改編號(hào)為1的圖書 現(xiàn)在編號(hào)為1的圖書的信息單獨(dú)顯示出來 你可以再次根據(jù)提示界面選擇修改圖書1的哪一項(xiàng)成分</p><p>  我們看到圖書1的作者為“無” 決定將

98、它改為“陳波”(如下圖)</p><p>  完成后可以利用瀏覽函數(shù)同樣可以查看到修改后的效果</p><p><b>  修改成功</b></p><p>  功能七之按編號(hào)刪除某本圖書:</p><p>  選擇要?jiǎng)h除圖書的編號(hào)前你也會(huì)看到目前所有圖書的信息</p><p>  現(xiàn)在選擇刪除編

99、號(hào)為8的圖書</p><p>  瀏覽看到編號(hào)為8的圖書已被成功刪除</p><p>  功能八之簡(jiǎn)單的統(tǒng)計(jì)功能(統(tǒng)計(jì)圖書總數(shù)目):</p><p>  主菜單中選擇5即可統(tǒng)計(jì)出圖書總數(shù)目(上圖看出還剩余編號(hào)為1、2、3、4、5、6、7、9)八本圖書</p><p>  統(tǒng)計(jì)正確 現(xiàn)在基本功能演示完畢 選擇0退出系統(tǒng)</p>

100、<p>  為了完善 系統(tǒng)也設(shè)計(jì)了一個(gè)幫助功能對(duì)系統(tǒng)的使用方法做了簡(jiǎn)單的介紹</p><p><b>  6 課程心得總結(jié)</b></p><p>  經(jīng)歷了幾個(gè)星期的課程設(shè)計(jì),從設(shè)計(jì)前期的不知如何下手到開始設(shè)計(jì)時(shí)的各種錯(cuò)誤的困擾再到一個(gè)個(gè)的攻破各個(gè)問題,最后到對(duì)程序的進(jìn)一步完善與課程報(bào)告的撰寫。這一段時(shí)間我們由被程序困擾到幾乎崩潰到最后成就感的油然而生

101、;從一整天的坐在電腦屏幕面前到現(xiàn)在的帶著喜悅一遍一遍運(yùn)行著程序;一遍遍的互相探討解決大家遇到的問題到越來越發(fā)現(xiàn)編程的有意思,我到現(xiàn)在真的感覺認(rèn)真自己做完這樣一個(gè)系統(tǒng)收獲頗大:</p><p>  對(duì)結(jié)構(gòu)化程序設(shè)計(jì)與函數(shù)的嵌套調(diào)用有了更清晰具體的認(rèn)識(shí)</p><p>  對(duì)鏈表的操作更加熟練,更清晰的認(rèn)識(shí)到鏈表與其他我們前面學(xué)習(xí)的數(shù)據(jù)類型(如結(jié)構(gòu)體)的區(qū)別與聯(lián)系,及使用方法上的異同</

102、p><p>  明確認(rèn)識(shí)到鏈表的循環(huán)操作要注意到的是前一部分對(duì)某某進(jìn)行操作處理,而后要分析好對(duì)于如何實(shí)現(xiàn)對(duì)某某重新賦值等變化來實(shí)現(xiàn)繼續(xù)循環(huán)</p><p>  引入了文件知識(shí)可以對(duì)電腦硬盤上的數(shù)據(jù)操作,改變了對(duì)C語言的狹義認(rèn)識(shí),認(rèn)識(shí) 到C語言實(shí)際上還可以實(shí)現(xiàn)更復(fù)雜豐富的功能來利用開發(fā)的軟件來進(jìn)一步實(shí)現(xiàn)對(duì)現(xiàn)實(shí)中的問題的解決</p><p>  學(xué)習(xí)到C語言的學(xué)習(xí)一定不不能

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論