數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--圖書(shū)管理_第1頁(yè)
已閱讀1頁(yè),還剩87頁(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)介

1、<p>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告</p><p><b>  題目:圖書(shū)管理</b></p><p>  學(xué) 院 計(jì)算機(jī)學(xué)院 </p><p>  專 業(yè) 軟件工程 </p><p>  年級(jí)班別 2010級(jí) 4 班 </p>&l

2、t;p>  學(xué) 號(hào) </p><p>  學(xué)生姓名 </p><p>  指導(dǎo)教師 </p><p>  成 績(jī) ____________________</p><p><b>  2012

3、年6月</b></p><p>  設(shè)計(jì)任務(wù)【Design Tasks】</p><p>  1.1、圖書(shū)管理系統(tǒng)中圖書(shū)管理模塊包括圖書(shū)類型定義:書(shū)號(hào)、現(xiàn)存量、總存量,出版時(shí)間為整型,定價(jià)為浮點(diǎn)型,書(shū)名、著者名為字符型,借閱指針、預(yù)約指針為讀者類型;讀者類型定義:證號(hào)為整型、姓名為字符型,另外借閱類型和預(yù)約類型組合成其中的共用體類型。B樹(shù)(2-3樹(shù))類型定義:關(guān)鍵字個(gè)數(shù)和關(guān)鍵字

4、數(shù)組為整型、另外還有指向雙親的指針、指向子樹(shù)的指針、記錄單元指針;B樹(shù)查找結(jié)果類型定義: 節(jié)點(diǎn)指針、關(guān)鍵字序號(hào)和查找標(biāo)志變量為整型。</p><p>  1.2、演示程序以用戶和計(jì)算機(jī)的對(duì)話方式進(jìn)行,在計(jì)算機(jī)終端上顯示“提示信息”之后,由用戶在鍵盤上輸入演示程序中規(guī)定的運(yùn)算命令,相應(yīng)的輸入數(shù)據(jù)和運(yùn)算結(jié)果顯示在后面。該演示系統(tǒng),沒(méi)有使用文件,全部數(shù)據(jù)放在內(nèi)存存放。四項(xiàng)基本業(yè)務(wù)都以書(shū)號(hào)為關(guān)鍵字進(jìn)行的,采用了B樹(shù)(2-

5、3樹(shù))對(duì)書(shū)號(hào)建立索引,以提高效率。</p><p>  2、設(shè)計(jì)思路【Design Ideas】</p><p><b>  2.1、設(shè)計(jì)框圖</b></p><p><b>  2.2、結(jié)構(gòu)體設(shè)計(jì)</b></p><p>  /*------------------- 四、所需結(jié)構(gòu)體和類-----

6、--------------*/</p><p><b>  //登陸類</b></p><p>  class Login</p><p><b>  {</b></p><p><b>  public:</b></p><p><b> 

7、 Login();</b></p><p>  void amend( const string st1,const string st2);</p><p>  bool IsLogin(string &str1, string &str2);</p><p>  string UserName;</p><p>

8、;  string UserID;</p><p>  string PassWord;</p><p>  int ErrorNum;</p><p><b>  };</b></p><p><b>  //個(gè)人信息結(jié)構(gòu)體</b></p><p>  typedef s

9、truct Information</p><p><b>  {</b></p><p>  string ID;</p><p>  string Name;</p><p>  string Academy;</p><p>  string Major;</p><p&

10、gt;  string Education;</p><p>  string State;</p><p>  int number;//超期數(shù)目</p><p>  inttotal;//已借數(shù)目</p><p><b>  }Inof;</b></p><p><b> 

11、 //借閱信息結(jié)構(gòu)體</b></p><p>  typedef struct InofBook</p><p><b>  {</b></p><p>  //string Check_Data;</p><p>  //string Return_Data;</p><p>  i

12、nt C_Year;</p><p>  int C_Month;</p><p>  int C_Day;</p><p>  int R_Year;</p><p>  int R_Month;</p><p>  int R_Day;</p><p>  int Book_Number;&

13、lt;/p><p>  string Book_Name;</p><p>  string Book_Writer;</p><p>  struct InofBook *next;</p><p>  }InofBook;</p><p><b>  //圖書(shū)信息類</b></p>

14、<p>  typedef struct{</p><p>  KeyType index; //書(shū)號(hào)</p><p>  char B_name[1][20];//書(shū)名,可以為中文</p><p>  char B_writer[1][20];//著者,可以中文</p><p>  int stack;//現(xiàn)存量</p>

15、;<p>  int total;//總庫(kù)存量</p><p>  int tag;//標(biāo)志是否被預(yù)約 1 是 0 否</p><p>  }B_Record,*b_Record; //書(shū)目記錄類型</p><p><b>  //圖書(shū)類</b></p><p>  struct book</p>

16、;<p><b>  {</b></p><p><b>  public:</b></p><p><b>  Book();</b></p><p>  elemtype Book_Name;</p><p>  elemtype Book_Writer;&l

17、t;/p><p>  int Book_Number;</p><p>  int Extant_Num ;//該書(shū)現(xiàn)存量</p><p>  int Gross_Num ;//該書(shū)總量</p><p>  struct book *next;</p><p><b>  };</b></p

18、><p>  typedef struct book *book_Record;</p><p>  typedef struct book Book_Record;</p><p>  typedef struct R_Record{</p><p>  KeyType card; //卡號(hào)</p><p>  char

19、 R_name[1][20];//姓名</p><p>  char tel[11];//手機(jī)號(hào)碼</p><p>  char* PassWord;</p><p>  struct Borrow{</p><p>  int yuyue;//存放預(yù)約的書(shū)號(hào),最多一本</p><p>  struct bNode *

20、R_book[N/4];//借閱書(shū)指針</p><p>  char* term[N/4];//歸還期限</p><p>  int b_num;//已經(jīng)借閱書(shū)的數(shù)量</p><p>  }bor;//借閱記錄類型</p><p>  }R_Record,*r_Record; //讀者記錄類型</p><p>  ty

21、pedef struct bNode{ </p><p>  KeyType index; //關(guān)鍵字向量</p><p>  struct B_Node *child; //子樹(shù)指針向量</p><p>  B_Record rec; //記錄指針向量</p><p>  }bNode,*Bode;//書(shū)目結(jié)點(diǎn)向量類型</p>

22、<p>  typedef struct rNode{</p><p>  KeyType card; //卡號(hào)向量</p><p>  struct R_Node *child; //子樹(shù)指針向量</p><p>  R_Record rec; //記錄指針向量</p><p>  }rNode,*Rode; //讀者結(jié)點(diǎn)向量類

23、型</p><p>  typedef struct B_Node{</p><p>  int BookNum; //結(jié)點(diǎn)中書(shū)目個(gè)數(shù),即結(jié)點(diǎn)的大小</p><p>  int level;</p><p>  struct B_Node *pa; //指向雙親結(jié)點(diǎn)</p><p>  struct B_Node *l

24、Bro, *rBro;</p><p>  struct bNode node[m+1];//除child外,其它0號(hào)單元未用</p><p>  }B_Node,*Book; //書(shū)樹(shù)結(jié)點(diǎn)和書(shū)樹(shù)的類型</p><p>  typedef struct R_Node{</p><p>  int ReaderNum; //結(jié)點(diǎn)中讀者個(gè)數(shù),即結(jié)

25、點(diǎn)的大小</p><p>  int level;</p><p>  struct R_Node *pa; //指向雙親結(jié)點(diǎn)</p><p>  struct R_Node *lBro, *rBro;</p><p>  struct rNode node[m+1]; //除child外,0號(hào)單元未用</p><p>

26、;  }R_Node,*Reader; //讀者樹(shù)結(jié)點(diǎn)和讀者樹(shù)的類型</p><p>  typedef struct{</p><p>  B_Node *pb; //指向找到的結(jié)點(diǎn)</p><p>  int i; //1..m,在結(jié)點(diǎn)中的關(guān)鍵字序號(hào)</p><p>  int tag; // 1:查找成功,O:查找失敗</p>

27、;<p>  }B_Result; //書(shū)樹(shù)的查找結(jié)果類型</p><p>  typedef struct{</p><p>  R_Node *pr; //指向找到的結(jié)點(diǎn)</p><p>  int i; //1..m,在結(jié)點(diǎn)中的關(guān)鍵字序號(hào)</p><p>  int tag; // 1:查找成功,O:查找失敗</p&

28、gt;<p>  }R_Result; //讀者樹(shù)的查找結(jié)果類型</p><p>  2.3、宏定義和常量</p><p>  #define TRUE 1</p><p>  #define FALSE 0</p><p>  #define OK 1</p><p>  #define ERROR 0

29、</p><p>  #define EQ(a,b) ((a)==(b))</p><p>  #define LT(a,b) ((a)<(b))</p><p>  #define HT(a,b) ((a)>(b)</p><p>  #define m 3 //2-3樹(shù)的階</p><p>  #def

30、ine N 20 // 每種書(shū)最大庫(kù)存20本、讀者最多每人借 20/4 = 5 本</p><p>  typedef int Status; //函數(shù)的類型,其值是函數(shù)結(jié)果狀態(tài)代碼</p><p>  typedef int KeyType; //設(shè)關(guān)鍵字域?yàn)檎?lt;/p><p>  typedef string elemtype;</p><

31、p><b>  2.4、設(shè)計(jì)模塊</b></p><p><b>  主程序模塊</b></p><p><b>  ↓</b></p><p>  圖 書(shū) 管 理 模 塊</p><p>  ↓ ↓</p><p>  

32、圖書(shū)管理模塊 我的圖書(shū)館管理模塊</p><p>  三、部分代碼分析【Code Analysis】</p><p>  3.1、圖書(shū)管理模塊選擇</p><p>  switch(i){</p><p>  case 1: //添加圖書(shū)</p><p>  A_Add_Book( head );</p&

33、gt;<p>  save_printf(1,"\n\t\t書(shū)庫(kù)現(xiàn)狀態(tài)如下: \n");</p><p>  if(BK->BookNum != NULL)</p><p>  Traverse_BK(BK,BK->level);</p><p><b>  else</b></p>

34、<p>  save_printf(1,"\n書(shū)庫(kù)為空");</p><p>  fprintf(fp,"\n\n");</p><p>  printf("\n\n");</p><p><b>  break;</b></p><p>  cas

35、e 2: //查找圖書(shū)</p><p>  A_Search_Book();</p><p><b>  break;</b></p><p>  case 3: //刪除圖書(shū)</p><p>  A_Delete_Book( head );</p><p>  save_printf(1

36、,"\n\t\t書(shū)庫(kù)現(xiàn)狀態(tài)如下: \n");</p><p>  if(BK->BookNum != NULL)</p><p>  Traverse_BK(BK,BK->level);</p><p><b>  else</b></p><p>  save_printf(1,&qu

37、ot;\n書(shū)庫(kù)為空");</p><p>  fprintf(fp,"\n\n");</p><p>  printf("\n\n");</p><p><b>  break;</b></p><p>  case 4: //查看全部圖書(shū)</p>&l

38、t;p>  Search_All_Book();</p><p><b>  break;</b></p><p>  case 5://我的圖書(shū)館</p><p>  Mylibrary( head );</p><p><b>  break;</b></p><p&

39、gt;  case 0: //返回系統(tǒng)登錄界面</p><p>  fprintf(fp,"\n\t\t\t☆\tAdmin_menu-->menu \t☆\n\n");</p><p><b>  exit(1);</b></p><p><b>  break;</b></p>

40、<p><b>  default:</b></p><p>  save_printf(1,"\n\t您的操作有誤,請(qǐng)重新選擇(0→7): ");</p><p><b>  break;</b></p><p><b>  }</b></p><

41、;p>  3.2.1、添加圖書(shū)</p><p>  /*----------------------------- A_Add_Book ------------------------------*/</p><p>  void Load( book_Record q );</p><p>  void A_Add_Book( book_Rec

42、ord head ){//添加圖書(shū)</p><p>  char s[2];</p><p><b>  int i;</b></p><p><b>  int j;</b></p><p>  book_Recordq;</p><p>  q = new Book_R

43、ecord;</p><p>  B_Record r;</p><p>  Init_Brec(r);</p><p><b>  do{</b></p><p>  book_Record p=head;</p><p>  save_printf(1,"\n\t書(shū)號(hào): "

44、;);</p><p>  save_gets(s);</p><p>  r.index = atoi(s);</p><p>  if(r.index <= NULL || r.index >9999999) </p><p>  save_printf(1,"\n\t輸入有誤,請(qǐng)重新輸入(1→9999999)!\n

45、");</p><p><b>  /*</b></p><p>  **主關(guān)鍵字是圖書(shū)編號(hào),是唯一的</p><p>  **輸入相同編號(hào),重新輸入</p><p><b>  */</b></p><p>  while( p != NULL )</p&g

46、t;<p><b>  {</b></p><p>  if( p->Book_Number == r.index )</p><p><b>  {</b></p><p>  r.index = NULL;</p><p>  cout<<"\t該編號(hào)已

47、存在!"<<endl;</p><p><b>  }</b></p><p>  p = p->next;</p><p><b>  }</b></p><p>  }while(r.index<=NULL || r.index > 9999999);&l

48、t;/p><p>  save_printf(1,"\n\t書(shū)名: ");</p><p><b>  do{</b></p><p>  save_gets(r.B_name[0]);</p><p>  j = strlen(r.B_name[0]);</p><p>  i

49、f(j <= 0 || j > 20)</p><p>  save_printf(1,"\n\t您輸入的書(shū)名有誤,請(qǐng)重新輸入(1→20字符): ");</p><p>  }while(j <= 0 || j > 20);</p><p>  save_printf(1,"\n\t著者: ");&

50、lt;/p><p><b>  do{</b></p><p>  save_gets(r.B_writer[0]);</p><p>  j = strlen(r.B_writer[0]);</p><p>  if(j <= 0 || j > 20)</p><p>  save_pr

51、intf(1,"\n\t您輸入的著者有誤,請(qǐng)重新輸入(1→20字符): ");</p><p>  }while(j <= 0 || j > 20);</p><p>  save_printf(1,"\n\t存入數(shù)量: ");</p><p><b>  do{</b></p>

52、;<p>  save_gets(s);</p><p>  r.stack = r.total = atoi(s);</p><p>  if(r.total <= NULL || r.total > N ) save_printf(1,"\n\t輸入有誤,請(qǐng)重新輸入(1→20)!: ");</p><p>  }w

53、hile(r.total <= NULL || r.total > N);</p><p>  i = Add_Book(BK,r);</p><p><b>  if(i)</b></p><p><b>  {</b></p><p><b>  /*讀取信息*/</

54、b></p><p>  q->Book_Number = r.index;</p><p>  q->Book_Name = r.B_name[0];</p><p>  q->Book_Writer = r.B_writer[0];</p><p>  q->Extant_Num = r.stack;<

55、/p><p>  q->Gross_Num = r.total;</p><p>  Load(q);//將新書(shū)添加到圖書(shū)庫(kù)中</p><p>  q->next = head;</p><p><b>  head = q;</b></p><p>  Load_Book( head )

56、;//更新“l(fā)ibrarydata.txt”圖書(shū)信息</p><p>  save_printf(1,"\n\t添加成功!\n");</p><p><b>  }</b></p><p><b>  else </b></p><p><b>  {</b>

57、;</p><p>  save_printf(1,"\n\t添加失敗!該書(shū)書(shū)庫(kù)容量不足!\n");</p><p><b>  }</b></p><p><b>  }</b></p><p>  3.2.2、刪除圖書(shū)</p><p>  /*----

58、------------------------- A_Delete_Book ------------------------------*/</p><p>  book_Record Dell( int index );</p><p>  void load_book( book_Record h);</p><p>  void A_Delet

59、e_Book( book_Record head ){//刪除圖書(shū)</p><p>  char s[2];</p><p><b>  int i;</b></p><p>  int index;</p><p>  //book_Record x;</p><p>  //x = new

60、 Book_Record;</p><p><b>  do{</b></p><p>  save_printf(1,"\n\t請(qǐng)輸入您要?jiǎng)h除的書(shū)的書(shū)號(hào): ");</p><p>  book_Record p= head;</p><p>  save_gets(s);</p>

61、<p>  index = atoi(s);</p><p>  if(index <= 0 || index > 9999999) save_printf(1,"\n\t輸入有誤,請(qǐng)重新輸入(1→9999999)!\n書(shū)號(hào): ");</p><p>  /*處理圖書(shū)不出在的情況*/</p><p>  while( p

62、!= NULL )</p><p><b>  {</b></p><p>  if( p->Book_Number == index )</p><p><b>  break;</b></p><p>  p = p->next;</p><p><b&

63、gt;  }</b></p><p>  if(p==NULL)</p><p><b>  {</b></p><p><b>  index=0;</b></p><p>  cout<<"無(wú)此書(shū)!"<<endl;</p>&

64、lt;p><b>  }</b></p><p>  }while(index <= 0 || index > 9999999);</p><p>  i = Delete_Book(BK,index);</p><p><b>  if(i)</b></p><p><b&

65、gt;  {</b></p><p>  //x->Book_Number = index;</p><p>  head = Dell(index);//刪除圖書(shū)</p><p>  load_book( head );//更新圖書(shū)庫(kù)圖書(shū)信息</p><p>  Load_Book( head );//更新圖書(shū)庫(kù)圖書(shū)信息

66、</p><p>  save_printf(1,"\n\t刪除成功!\n");</p><p><b>  }</b></p><p>  else save_printf(1,"\n\t刪除失敗,館內(nèi)不存在該書(shū)!\n");</p><p><b>  }</b&

67、gt;</p><p>  3.2、我的圖書(shū)館管理模塊選擇</p><p><b>  switch(n)</b></p><p><b>  {</b></p><p>  case 1: Information();break;//輸出個(gè)人信息、狀態(tài)</p><p>

68、  case 2: Amend( login );break;//修改密碼</p><p>  case 3: Checkdata();break;//當(dāng)前借閱信息</p><p>  case 4: Recall();break;//催還信息</p><p>  case 5:Check_out(head);break;//借書(shū)</p>&l

69、t;p>  case 6: Return_book( head );break;//還書(shū)</p><p>  case 7: Find_Book(head);break;//查找</p><p>  case 0: Admin_menu();break;//還回首頁(yè)</p><p><b>  //</b></p>

70、<p>  default: printf("\t\t\t\t輸入信息錯(cuò)誤,請(qǐng)重新輸入!\n"); break;</p><p><b>  }</b></p><p>  3.2.1、修改密碼</p><p>  /*采用 * 字符輸入密碼*/</p><p>  while ( (c=g

71、etch()) != 13 )</p><p><b>  {</b></p><p>  if (c!='\b' && c!='\t' && count<20)</p><p><b>  {</b></p><p>  pas

72、s[count++] = c;</p><p>  putchar('*');</p><p><b>  }</b></p><p>  if ( c == '\b' && count>0)</p><p><b>  {</b></p&

73、gt;<p>  printf("\b \b"); </p><p><b>  count--; </b></p><p><b>  }</b></p><p><b>  }</b></p><p>  pass[count] = &#

74、39;\0';</p><p>  password = pass;</p><p>  cout<<endl;</p><p>  /*導(dǎo)入密碼文件,讀取密碼和賬號(hào)*/</p><p>  char *file= "password";</p><p>  ofstream f

75、out;</p><p>  fout.open( file, ios::out );</p><p>  if( !fout.is_open() )</p><p><b>  {</b></p><p>  cerr<<file<<" 修改失敗!"<<endl;

76、</p><p><b>  exit(1);</b></p><p><b>  }</b></p><p>  fout<<username<<setw(20)<<password<<setw(20)<<login.UserName;//修改后,重新寫會(huì)密碼文

77、件</p><p>  fout.close();</p><p>  login.amend( username, password);</p><p><b>  3.2.2、借書(shū)</b></p><p>  /**************************借書(shū)*************************

78、*******/</p><p>  void Library_card( book_Record p );</p><p>  void Load_Book( book_Record head );</p><p>  void Check_out( book_Record head )</p><p><b>  {</b

79、></p><p>  system("cls");</p><p>  system("color f9");</p><p>  save_printf("\n\t ※※※※※※※※※※※※※※※※※※※※※※※※※※※※\n");</p><p>  save_pri

80、ntf( "\t ※ ※\n");</p><p>  save_printf( "\t ※****************借**書(shū)********界**面*************** ※\n");</p><p>  save_pri

81、ntf( "\t ※ ※\n");</p><p>  save_printf( "\t ※ ※\n");</p><p>  save

82、_printf( "\t ※※※※※※※※※※※※※※※※※※※※※※※※※※※※\n");</p><p>  Traverse_Book(BK);</p><p><b>  int st;</b></p><p>  int sum,i=0;</p><p>  book_Record p

83、;</p><p>  int st1[3],st2[3];</p><p><b>  int st3;</b></p><p>  elemtype st4,st5;</p><p>  ifstream fin;</p><p>  cout<<"\n\n請(qǐng)輸入要借書(shū)

84、的數(shù)目: ";</p><p><b>  cin>>sum;</b></p><p>  while( i<sum )</p><p><b>  {</b></p><p>  int flag = 0;</p><p>  int f = 0

85、;</p><p>  printf("請(qǐng)輸入要借第 %d 本書(shū)的編號(hào):", i+1 );</p><p><b>  cin>>st;</b></p><p>  cout<<endl;</p><p><b>  p = head;</b></p

86、><p><b>  /*</b></p><p><b>  **查找借閱的書(shū)</b></p><p><b>  */</b></p><p>  while( p!=NULL )</p><p><b>  {</b></p

87、><p>  if( p->Book_Number == st )</p><p><b>  {</b></p><p>  if( p->Extant_Num != 0 )</p><p><b>  {</b></p><p>  fin.open( "

88、;librarydata.txt", ios::in );</p><p>  if( fin.is_open() )</p><p><b>  {</b></p><p>  while( fin>>st1[0] && fin>>st1[1] && fin>>st

89、1[2] </p><p>  && fin>>st2[0] && fin>>st2[1] && fin>>st2[2] </p><p>  && fin>>st3 && fin>>st4 && fin>>st5 )<

90、;/p><p><b>  {</b></p><p>  if( st3 == st )</p><p><b>  {</b></p><p><b>  f = 1;</b></p><p><b>  flag = 1;</b>

91、;</p><p>  cout<<"你已經(jīng)借了這本書(shū)了!"<<endl;</p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  }</b></p>&l

92、t;p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  cout<<"打開(kāi)文件失敗!"<<endl;</p><p><b>  }&l

93、t;/b></p><p>  ///////////////////////////////////////////////////////</p><p>  if( f == 0 )</p><p><b>  {</b></p><p>  p->Extant_Num--;</p>&l

94、t;p><b>  flag = 1;</b></p><p>  //添加到個(gè)人圖書(shū)庫(kù)中</p><p>  Library_card( p );</p><p><b>  }</b></p><p>  fin.close();</p><p><b>

95、  }</b></p><p><b>  break;</b></p><p><b>  }</b></p><p>  p = p->next ;</p><p><b>  }</b></p><p>  if( flag ==

96、 0 )</p><p><b>  {</b></p><p>  if( p != NULL )</p><p>  cout<<"該書(shū)已被借完!"<<endl;</p><p><b>  else</b></p><p> 

97、 cout<<" 圖書(shū)館無(wú)此書(shū)!"<<endl;</p><p><b>  }</b></p><p><b>  i++;</b></p><p><b>  }</b></p><p><b>  //更新圖書(shū)庫(kù)信息&

98、lt;/b></p><p>  Load_Book( head );</p><p>  system("pause");</p><p><b>  }</b></p><p><b>  3.2.2、還書(shū)</b></p><p>  /****

99、**********************還書(shū)********************************/</p><p>  void Return_Book( book_Record p );</p><p>  void Return_book( book_Record head )</p><p><b>  {</b><

100、/p><p>  system("cls");</p><p>  system("color f9");</p><p>  save_printf("\n\t ※※※※※※※※※※※※※※※※※※※※※※※※※※※※\n");</p><p>  save_printf( &q

101、uot;\t ※ ※\n");</p><p>  save_printf( "\t ※****************還**書(shū)********界**面*************** ※\n");</p><p>  save_printf( &q

102、uot;\t ※ ※\n");</p><p>  save_printf( "\t ※ ※\n");</p><p>  save_printf(

103、 "\t ※※※※※※※※※※※※※※※※※※※※※※※※※※※※\n");</p><p><b>  int st;</b></p><p>  int sum,i=0;</p><p>  book_Record p;</p><p>  cout<<"\n\n請(qǐng)輸入

104、要還書(shū)的數(shù)目: ";</p><p><b>  cin>>sum;</b></p><p>  while( i<sum )</p><p><b>  {</b></p><p>  int flag = 0;</p><p>  printf

105、("請(qǐng)輸入要還的第 %d 本書(shū)的編號(hào):", i+1 );</p><p><b>  cin>>st;</b></p><p>  cout<<endl;</p><p><b>  p = head;</b></p><p>  while( p!=NU

106、LL )</p><p><b>  {</b></p><p>  if( p->Book_Number == st )</p><p><b>  {</b></p><p>  if( p->Extant_Num <= p->Gross_Num )</p>

107、<p><b>  {</b></p><p>  p->Extant_Num++;</p><p>  Return_Book( p );//刪除該書(shū),更新個(gè)人圖書(shū)庫(kù)</p><p><b>  flag = 1;</b></p><p>  //cout<<&qu

108、ot;\n編號(hào)"<<setw(20)<<"書(shū)名"<<setw(20)<<"作者"<<endl;</p><p>  //cout<<p->Book_Number<<setw(20)<<p->Book_Name<<setw(15)<<

109、p->Book_Writer<<endl;</p><p>  cout<<"\n編號(hào): "<<p->Book_Number<<endl;</p><p>  cout<<"\n書(shū)名: "<<p->Book_Name<<endl;</p>

110、<p>  cout<<"\n作者: "<<p->Book_Writer<<endl;</p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  else</b>&l

111、t;/p><p>  cout<<"您沒(méi)有借這本書(shū)!"<<endl;</p><p><b>  flag = 1;</b></p><p><b>  }</b></p><p>  p = p->next ;</p><p>

112、<b>  }</b></p><p>  if( flag == 0 )</p><p><b>  {</b></p><p>  cout<<" 圖書(shū)館無(wú)此書(shū)!輸入編號(hào)錯(cuò)誤!"<<endl;//這行輸不出</p><p><b>  }&l

113、t;/b></p><p><b>  i++;</b></p><p><b>  }</b></p><p><b>  //圖書(shū)館信息更新</b></p><p>  Load_Book( head );</p><p>  system(&

114、quot;pause");</p><p><b>  }</b></p><p>  四、部分測(cè)試結(jié)果【test result】</p><p><b>  4.0、主界面</b></p><p><b>  4.1、系統(tǒng)界面</b></p><

115、p><b>  4.2、登陸界面</b></p><p>  4.3、個(gè)人用戶界面</p><p>  4.4、修改密碼界面</p><p>  4.5、個(gè)人信息界面</p><p>  4.6、當(dāng)前借閱界面</p><p><b>  4.7、借書(shū)界面</b><

116、/p><p><b>  4.8、還書(shū)界面</b></p><p><b>  4.9、查找書(shū)</b></p><p>  4.10、顯示所有書(shū)</p><p>  4.11、2-3樹(shù)凹進(jìn)顯示所有書(shū)</p><p><b>  4.12、刪去書(shū)</b><

117、;/p><p><b>  4.13、添加新書(shū)</b></p><p><b>  4.13、退出系統(tǒng)</b></p><p>  5、總結(jié)【summary】</p><p>  5.1、通過(guò)這次課程設(shè)計(jì),我系統(tǒng)的復(fù)習(xí)了C語(yǔ)言,把大一所學(xué)的C語(yǔ)言基本上重新掌握了一遍。</p><p&

118、gt;  5.2、圖書(shū)管理系統(tǒng)涉及的知識(shí)很多,我必須不斷地查找相關(guān)文獻(xiàn),提高我的知識(shí)視野,同時(shí)也提高了我的實(shí)踐能力</p><p>  5.3、本課程設(shè)計(jì)難點(diǎn)在以2-3B樹(shù)的現(xiàn)實(shí),我通過(guò)建立兩個(gè)圖書(shū)庫(kù)將2-3B樹(shù)和單鏈表相結(jié)合,從而簡(jiǎn)化了程序設(shè)計(jì)。</p><p>  5.4、我最大的收獲就是鍛煉了我的實(shí)際操作能力。讓我在不斷遇到問(wèn)題時(shí),不斷的去尋找解決問(wèn)題的答案,從而使自己不斷想出goo

119、d ideas,不斷完善自己的系統(tǒng)功能和優(yōu)化界面。</p><p>  5、參考文獻(xiàn)【reference documents】</p><p>  【1】數(shù)據(jù)結(jié)構(gòu)[專著]:C語(yǔ)言版/嚴(yán)蔚敏, 吳偉民編著.—北京:清華大學(xué)出版社,2007</p><p>  【2】C語(yǔ)言程序設(shè)計(jì)[專著]/譚浩強(qiáng)著.—2版.—北京:清華大學(xué)出版社,2008</p><

120、;p>  【3】C++ Primer Plus(第五版)中文版[中譯文]/(美)Stephen Prata著;孫建春,韋強(qiáng)譯.—北京:人民郵電出版社,2005</p><p>  7、源代碼【source code】</p><p>  ////////////////////////////////////////////////////////////main.cpp/////

121、///////////////////////////////////////////////////////////////</p><p>  #include"head.h"</p><p>  void Admin_menu();</p><p>  int main(){//主函數(shù),只負(fù)責(zé)打開(kāi)文件,及調(diào)用主菜單、初始化</p>

122、;<p>  system("cls");</p><p>  if((fp = fopen("log.txt","w+"))==NULL){</p><p>  save_printf(1,"\n\t\n打開(kāi)文件時(shí)發(fā)生錯(cuò)誤!系統(tǒng)將自動(dòng)退出!");</p><p>  _s

123、leep(1000);save_printf("\t\t\t★");</p><p>  _sleep(1000);save_printf("\t★");</p><p>  _sleep(1000);save_printf("\t★");</p><p><b>  exit(1);</b

124、></p><p><b>  }</b></p><p>  fprintf(fp,"\n\t\t\t☆\tmain-->menu \t☆\n\n");</p><p>  Init_Book(BK);</p><p>  Init_Reader(Rr);</p><

125、;p>  Admin_menu();</p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  ////////////////////////////////////////////////////////////////////head.h////////

126、////////////////////////////////////////////////</p><p>  /*------------------- 一、包含的頭文件---------------------*/</p><p>  #include<fstream></p><p>  #include<cstdlib><

127、/p><p>  #include <ctime></p><p>  #include<vector></p><p>  #include<iomanip></p><p>  #include<malloc.h></p><p>  #include <conio

128、.h></p><p>  #include <malloc.h> //包含內(nèi)存分配函數(shù)的函數(shù)聲明;還定義常量和表現(xiàn)由堆例程使用的類型</p><p>  #include <stdio.h> //標(biāo)準(zhǔn)輸入輸出頭文件</p><p>  #include <conio.h> //定義了通過(guò)控制臺(tái)進(jìn)行數(shù)據(jù)輸入和數(shù)據(jù)輸出的函數(shù)&

129、lt;/p><p>  #include <stdlib.h> //定義了五種類型、一些宏和通用工具函數(shù).包含了C、C++語(yǔ)言的最常用的系統(tǒng)函數(shù)</p><p>  #include <string> </p><p>  #include <time.h> //時(shí)間和日期處理函數(shù)</p><p>  #inc

130、lude <windows.h></p><p>  #include <iostream></p><p>  using namespace std; //使用命名空間std</p><p>  /*------------------- 二、所需函數(shù)-------------------*/</p><p>  

131、void Admin_menu();</p><p>  /*------------------- 三、宏定義和常量-------------------*/</p><p>  #define TRUE 1</p><p>  #define FALSE 0</p><p>  #define OK 1</p><p&

132、gt;  #define ERROR 0</p><p>  #define EQ(a,b) ((a)==(b))</p><p>  #define LT(a,b) ((a)<(b))</p><p>  #define HT(a,b) ((a)>(b)</p><p>  #define m 3 //2-3樹(shù)的階</p&

133、gt;<p>  #define N 20 // 每種書(shū)最大庫(kù)存20本、讀者最多每人借 20/4 = 5 本</p><p>  typedef int Status; //函數(shù)的類型,其值是函數(shù)結(jié)果狀態(tài)代碼</p><p>  typedef int KeyType; //設(shè)關(guān)鍵字域?yàn)檎?lt;/p><p>  typedef string elemt

134、ype;</p><p>  /*------------------- 四、所需結(jié)構(gòu)體和類-------------------*/</p><p><b>  //登陸類</b></p><p>  class Login</p><p><b>  {</b></p><p

135、><b>  public:</b></p><p><b>  Login();</b></p><p>  void amend( const string st1,const string st2);</p><p>  bool IsLogin(string &str1, string &st

136、r2);</p><p>  string UserName;</p><p>  string UserID;</p><p>  string PassWord;</p><p>  int ErrorNum;</p><p><b>  };</b></p><p>

137、;<b>  //個(gè)人信息結(jié)構(gòu)體</b></p><p>  typedef struct Information</p><p><b>  {</b></p><p>  string ID;</p><p>  string Name;</p><p>  string

138、 Academy;</p><p>  string Major;</p><p>  string Education;</p><p>  string State;</p><p>  int number;//超期數(shù)目</p><p>  inttotal;//已借數(shù)目</p><

139、p><b>  }Inof;</b></p><p><b>  //借閱信息結(jié)構(gòu)體</b></p><p>  typedef struct InofBook</p><p><b>  {</b></p><p>  //string Check_Data;</

140、p><p>  //string Return_Data;</p><p>  int C_Year;</p><p>  int C_Month;</p><p>  int C_Day;</p><p>  int R_Year;</p><p>  int R_Month;</p>

141、<p>  int R_Day;</p><p>  int Book_Number;</p><p>  string Book_Name;</p><p>  string Book_Writer;</p><p>  struct InofBook *next;</p><p>  }InofBoo

142、k;</p><p><b>  //圖書(shū)信息類</b></p><p>  typedef struct{</p><p>  KeyType index; //書(shū)號(hào)</p><p>  char B_name[1][20];//書(shū)名,可以為中文</p><p>  char B_writer[

溫馨提示

  • 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ù)僅提供信息存儲(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)論