数据结构课设之——图书管理系统

这是大一下学期写的,之前想过往CSDN上写,奈何源码和文档一直在U盘上!!然而每次用完U盘就忘了这事了,时隔一年,天时地利人和,想起来这件事,今天一定要写完!

当然在写的时候也借鉴了前辈很多东西,在此感谢各位学长学姐,本文仅供大家参考!!

说明书下载地址点我跳转
首先是学校下发的任务书(一般都是设计内容要求)
设计内容:
设计一个计算机管理系统完成图书管理基本业务。
(1) 每种书的登记内容包括书号、书名、著作者、现存量和库存量;
(2) 读者信息包括读者编号、姓名、借阅记录;
(3) 对书号建立索引表(线性表)以提高查找效率;
(4) 要实现入库、借阅、归还等基本功能。
设计要求:
(1) 符合课题要求,实现相应功能;
(2) 要求界面友好美观,操作方便易行;
(3) 注意程序的实用性、安全性。

我记得第一天老师是先让写的需求分析,自己百度了点,加着又编了点~这部分问题不大,老师一般不会为难你的。
图书管理系统需求分析
开发背景:
在全国各大学校中,图书馆发挥着重要的作用。有人说,图书馆是一个大学的文化深度的标志。图书馆是一个专门收集、整理、保存、传播文献并提供利用的科学、文化、教育和科研机构。图书管理系统有着手工管理无法比拟的优点,如检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高图书管理的效率。因此,开发一套能够为用户提供充足的信息和快捷的查询手段的图书管理系统,将是非常必要的,也是十分及时的。
项目目标:
本项目的设计目标旨在方便图书管理员的操作,减少图书管理员的工作量并使其能更有效的管理书库中的图书,实现了传统的图书管理工作的信息化建设。本系统的服务对象为图书馆流通部门的工作人员,用户界面友好,不需计算机专业的专门训练即可使用本系统。
数据结构:(基本原理部分)
在本系统中,将会使用链式线性表的结构,会用到3个结构体,第一个结构体是关于书的,封装图书编号,名字,作者,现有量,库存量,以及录入的图书数量,连接下一本书的结构体指针;第二个结构体是关于借书的,封装借书的编号和还书的日期;第三个结构体是关于读者的,封装读者的编号,读者的名字,读者的当前借书信息数组(引入第二个结构体),当前的已借的数量,连接下一个读者的结构体指针。
功能模块:

  1. 主菜单 供用户选择功能
  2. 初始化函数 初始化输入书籍信息
  3. 菜单选择函数
  4. 增加新书籍
  5. 增加新读者
  6. 查询书籍信息
  7. 查询读者信息
  8. 借书函数
  9. 还书函数
  10. 将书籍信息写入文件
  11. 将读者信息写入文件
    在这里插入图片描述
    接下来上源代码:
#include<bits/stdc++.h>
#define Max 3  
#define k   2 
typedef struct book{ 
    char book_num[50];
    char book_name[50];
    char book_writer[50];
    int book_kc;
    int book_xy;
    struct book *next;
}BK;
typedef struct borrow{ 
    char borrow_book_num[50];
    char limit_date[50];
}BO;
typedef struct reader{
    char reader_num[50];
    char reader_name[50];
    int right;
    BO borrow[Max];
    struct reader *next;
}RD;
BK *h_book;
RD *h_reader;
  
void Init_book(){			//将图书信息进行初始化
    BK *p0;
    printf("\t\t\n欢迎使用本图书管理系统\n");
    printf("\n请先初始化图书信息\n");
    p0=(BK*)malloc(sizeof(BK));
    h_book=p0;
    printf("\n请输入图书信息:\n");
    printf("书号:");            
    scanf("%s",&p0->book_num);
    printf("书名:");           
    scanf("%s",&p0->book_name);
    printf("著作者:");           
    scanf("%s",&p0->book_writer);
    printf("库存量:");
	scanf("%d",&p0->book_kc);
	printf("现有量:");
	scanf("%d",&p0->book_xy); 
//  p0->book_xy=p0->book_kc;     
    p0->next=NULL;
    printf("\n录入图书信息完成,按任意键继续下一步操作\n");
   	system("pause");
    system("cls");
}

void Add_New(){										//新书入库
    BK *p,*p0,*p1; 
    p=p1=h_book;
    printf("\n新书入库模块\n");
    printf("\n请输入新书信息\n");
    p0=(BK *)malloc(sizeof(BK));
    printf("书的编号:");
    scanf("%s",&p0->book_num);
    while(strcmp(p0->book_num,p1->book_num)!=0&&p1->next!=NULL)
    p1=p1->next;
    if(strcmp(p0->book_num,p1->book_num)==0){	
        printf("\n此编号图书已存在,直接入库。\n"); 
        printf("新书库存量:");
        scanf("%d",&p0->book_kc);
        printf("新书现有量:");
	    scanf("%d",&p0->book_xy); 
        p1->book_kc+=p0->book_kc;
        p1->book_xy+=p0->book_xy;
    }
    else{										
        printf("书名:");
        scanf("%s",p0->book_name);
        printf("书作者:");
        scanf("%s",p0->book_writer);
        printf("新书库存量:");
        scanf("%d",&p0->book_kc);
        printf("新书现有量:");
	    scanf("%d",&p0->book_xy);
        while(p->next){
            p=p->next;
        }
        if(h_book==NULL) h_book=p0;   
        else p->next=p0;                 
        p0->next=NULL;
//      p0->book_xy=p0->book_kc; 
    }
    printf("\n新书入库完成,按任意键继续下一步操作。\n");
  	system("pause");
    system("cls");
}

void Add_Reader(){											//添加读者 
    RD *p,*p0 ; 
    p=h_reader;
    p0=(RD *)malloc(sizeof(RD));								
    printf("\n请输入读者的信息:\n");
    printf("读者书证号:");           
    scanf("%s",p0->reader_num);
    printf("读者姓名:"); 
	scanf("%s",p0->reader_name);
	p0->right=0;  
    for(int i=0;i<Max;i++)
    {
		strcpy(p0->borrow[i].borrow_book_num,"0"); 	
		strcpy(p0->borrow[i].limit_date,"0"); 
	}
//	p0->next=NULL;
    if(h_reader==NULL) h_reader=p0;   
    else 
	{
		while(p->next)
		{
			p=p->next;
		}
		p->next=p0;  
	}  
	p0->next=NULL;             
//      p0->book_xy=p0->book_kc; 
    printf("\n添加读者完成,按任意键继续下一步操作。\n");
  	system("pause");
    system("cls");
}

void Find_Reader(){				//查找读者信息
    RD *p;
    int i;
    char find_reader[10];
    p=h_reader;
    printf("\n读者信息查询模块\n");
    printf("\n请输入你要查询读者编号:");
    scanf("%s",find_reader);
    while(strcmp(p->reader_num,find_reader)!=0&&p->next)
    p=p->next;
    if(strcmp(p->reader_num,find_reader)==0){	 
        printf("\n读者编号:%s的信息为:\n",find_reader);
        printf("读者编号\t读者姓名"); 						//一个读者能借Max本书   
        printf("\n");
        printf("\t%s\t\t%s",p->reader_num,p->reader_name);
        for(i=0;i<Max;i++){		 
            printf("\n");
            printf("书%d的编号",i+1); 
            printf("\t书%d的归还日期",i+1); 
            printf("\n");
            printf("\t%s",p->borrow[i].borrow_book_num);
            printf("\t\t%s",p->borrow[i].limit_date); 
        }
        printf("\n");
    }
    else
    printf("\n此读者编号不存在,请核对!按任意键返回...");
	system("pause"); 
	system("cls");
}
 
void Find_Book(){//查找图书信息
    BK *p;
    char find_book[10]; 
    p=h_book;
    printf("\n图书信息查询模块\n");
    printf("\n请输入你要查询图书编号:");
    scanf("%s",find_book);
    while(strcmp(p->book_num,find_book)!=0&&p->next)
    p=p->next;
    if(strcmp(p->book_num,find_book)==0){	 
        printf("\n图书编号:%s的信息为:\n",find_book);
        printf("\n书编号\t\t书名\t作者\t现有量 \t库存量\n");
        printf("%s\t\t%s\t%s\t%d\t%d\n",p->book_num,p->book_name,p->book_writer,p->book_xy,p->book_kc);
    }
    else
    printf("\n此图书不存在,按任意键返回");
	system("pause");
	system("cls");
}

void Borrow_Book(){				//借书模块
    BK *p0; RD *p1;
    char bo_num[10],rea_num[10],lim_date[8];
    int i;
    p0=h_book; p1=h_reader;
    printf("\n借书模块\n");
    printf("\n请输入借书的读者编号:");   
    scanf("%s",rea_num);
    while(p1->next!=NULL&&strcmp(rea_num,p1->reader_num)!=0)     //判断读者是否存在
    p1=p1->next;
    if(p1->next==NULL&&strcmp(rea_num,p1->reader_num)!=0){  	//如果存在则继续,不存在则提示错误! 
        printf("\n此读者编号不存在!按任意键返回\n"); 
	    //system("pause");
	    //system("cls");
		//return 0;    
        goto END;                                               //goto语句通常与条件语句配合使用,可用来实现条件转移,构成循环,跳出循环体等功能,这里是不存在跳出循环 
    } 
    printf("\n请输入你要借的书的编号:"); 
    scanf("%s",bo_num);
    while(strcmp(bo_num,p0->book_num)!=0&&p0->next!=NULL)       //遍历一次图书链表,判断此图书是否存在
    p0=p0->next;
    if(p0->next==NULL&&strcmp(bo_num,p0->book_num)!=0){         //如果存在,则继续,不存在就、则提示错误!
        printf("\n此图书编号不存在!按任意键返回..\n");
        goto END;
    }
    else if(p0->book_xy<=0){ 
        printf("\n抱歉,此书已借完!请等待新书的到来!!\n按任意键返回....");
        goto END;
    } 
    else if(p1->right>=Max){                                   
        printf("\n不好意思,借书数目已足够多!不能再借书了!\n按任意键返回....");
        goto END;
    }
    else if(strcmp(p1->borrow[0].borrow_book_num,"0")!=0){//此读者若已经借书,再判断此读者是否要借两本一样的书
        for(i=0;i<Max;i++){        	            //遍历一次读者所借的书,如果发现有重复,则结束
            if(strcmp(p1->borrow[i].borrow_book_num,bo_num)==0){			 
                printf("\n抱歉!同一个读者不能同借两本相同的书!\n");
                goto END;
            }
	    }
	} 
    for(i=0;i<Max;i++){  
    		//测试:	printf("*****");
		      if(strcmp(p1->borrow[i].borrow_book_num,"0")==0){     //如果没有重复
                    printf("\n请输入你要归还图书的日期:"); 
                    scanf("%s",lim_date);
                    strcpy(p1->borrow[i].borrow_book_num,bo_num);     //记录所借书号,并且借书数目加一,现存量减一
                    strcpy(p1->borrow[i].limit_date,lim_date); 
			        p1->right++; 
                    p0->book_xy--;
                    printf("\n读者编号%s借书完毕!按任意键继续下步操作..",p1->reader_num);
                    goto END;
                }
            }
        END:	system("pause");
		        system("cls");
}

void Return_Book(){//还书模块
    BK *p; RD *q;
    int i,j,find=0;
    char return_book_num[50],return_reader_num[50];
    p=h_book; q=h_reader;
    printf("\n还书模块\n");
    printf("\n请输入要还书的读者编号:");  
    scanf("%s",return_reader_num);         
    while(q->next!=NULL&&strcmp(return_reader_num,q->reader_num)!=0) 
    q=q->next;
    if(q->next==NULL&&strcmp(return_reader_num,q->reader_num)!=0){
        find=2;                     //设置标志提前出错,则find=2,若借了,则find=1,若没借为find=0
        printf("\n此读者编号不存在!按任意键返回..\n");
        goto END; 
    }
    printf("\n请输入读者还书的编号:");
    scanf("%s",return_book_num);
    while(p->next!=NULL&&strcmp(return_book_num,p->book_num)!=0)
    p=p->next;
    if(p->next==NULL&&strcmp(return_book_num,p->book_num)!=0){
        find=2;                   //设置标志若提前出错,则find=2,若借了,则find=1,若没借为find=0
        printf("\n错误!此图书编号不存在!按任意键返回..\n");
        goto END;
    } 
    for(i=0;i<Max;i++)
    if(strcmp(return_book_num,q->borrow[i].borrow_book_num)==0){/*如果此读者借了此书*/  
        find=1;                  //设置标志若提前出错,则find=2,若借了,则find=1,若没借为find=0
        for(j=i;j<Max-1;j++){
            strcpy(q->borrow[j].borrow_book_num,q->borrow[j+1].borrow_book_num); 
            strcpy(q->borrow[j].limit_date,q->borrow[j+1].limit_date); 
        }
        strcpy(q->borrow[j+1].borrow_book_num,"0");
        strcpy(q->borrow[j+1].limit_date,"0");
        p->book_xy++;
        q->right--;
        printf("\n编号%s的读者还书完成!按任意键继续下步操作",return_reader_num);
        goto END;
    }
    if(find==0){
        printf("\n错误!此读者未借此书!按任意键返回..\n");   
	    goto END;  
    }
    END: 	system("pause");
	        system("cls");
}

void Save_Reader(){   				//保存读者信息到文件 
    FILE *fp_reader;   
    RD *p,*p0;
    p=h_reader;
    if((fp_reader=fopen("Reader.dat","wb"))==NULL){   
        printf("\n文件保存失败!\n请重新启动本系统...\n");
        exit(0);
    }
    while(p!=NULL){
        if(fwrite(p,sizeof(RD),1,fp_reader)!=1)   
        printf("\n写入文件失败!\n请重新启动本系统!\n");
        p0=p;
        p=p->next;
        free(p0); 
    }
    h_reader=NULL;
    fclose(fp_reader);    
}

void Save_Book(){ 				//保存图书信息到文件 
    FILE *fp_book;    
    BK *p,*p0;
    p=h_book;
    if((fp_book=fopen("Book.dat","wb"))==NULL){
        printf("\n文件保存失败!\n请重新启动本系统...\n");
        exit(0);
    }
    while(p!=NULL){
        if(fwrite(p,sizeof(BK),1,fp_book)!=1)                
        printf("\n写入文件失败!\n请重新启动本系统!\n");
        p0=p;
        p=p->next;
        free(p0); 
    }
    h_book=NULL;
    fclose(fp_book);  
}

void Save(){ 					//保存读者和图书信息到文件 
    Save_Reader();
    Save_Book();
}

void Load_Reader()  		 //加载已保存文件中的读者信息
{
    RD *p1,*p2,*p3;
    FILE *fp;           
    fp=fopen("Reader.dat","rb");     
    p1=(RD *)malloc(sizeof(RD));
    fread(p1,sizeof(RD),1,fp);    
    h_reader=p3=p2=p1;
    while(! feof(fp)){
        p1=(RD *)malloc(sizeof(RD));
        fread(p1,sizeof(RD),1,fp);
        p2->next=p1;
        p3=p2;
        p2=p1;
    }
    p3->next=NULL;
    free(p1);
    fclose(fp); 
}

void Load_Book(){ 				//加载已保存文件中的图书信息
    BK *p1,*p2,*p3;
    FILE *fp;            
    fp=fopen("Book.dat","rb");  
    p1=(BK *)malloc(sizeof(BK));
    fread(p1,sizeof(BK),1,fp); 
    h_book=p3=p2=p1;
    while(! feof(fp)){
        p1=(BK *)malloc(sizeof(BK));
        fread(p1,sizeof(BK),1,fp);
        p2->next=p1;
        p3=p2;
        p2=p1;
    } 
    p3->next=NULL;
    free(p1);
    fclose(fp);  
}

void Load(){				//加载总信息
    Load_Reader();
    Load_Book();
}

int Menu(){					//主菜单
    int sn;
    printf("\n\t\t图书管理系统主菜单\n");
    printf("*************************************************\n");
    printf("*\t\t1----新书入库 \t\t\t*\n");
    printf("*\t\t2----添加读者 \t\t\t*\n");
    printf("*\t\t3----查询图书 \t\t\t*\n");
    printf("*\t\t4----查询读者 \t\t\t*\n");
    printf("*\t\t5----借书模块 \t\t\t*\n");
    printf("*\t\t6----还书模块 \t\t\t*\n");
    printf("*\t\t0----退出程序 \t\t\t*\n");
    printf("*************************************************\n");
    printf("请选择相应的代号:"); 
    for(;;){
        scanf("%d",&sn);  
        if(sn<0||sn>6)
        printf("\n错误!请重新输入:");
        else break;
    }
    return sn; 
}

void Menu_select(){//主菜单选择函数
    for(;;){
        switch(Menu()){
		    case 0:
            system("cls");
            Save();
            printf("\n\n\t 数据保存成功!\n");	
            printf("\n\n\t欢迎下次使用本系统!\n"); 
            printf("\n\n\t		By:XXX\n");
            getchar(); 
            exit(0);
            case 1:Add_New();    break; 
            case 2:Add_Reader();    break; 
            case 3:Find_Book();  break;
            case 4:Find_Reader();break;
            case 5:Borrow_Book();break;
            case 6:Return_Book();break;
            default:printf("\n错误!");
			exit(0);
        }
    }
} 
main(){
    FILE *fp_book,*fp_reader;             
    if((fp_book=fopen("Book.dat","rb"))==NULL||(fp_reader=fopen("Reader.dat","rb"))==NULL){
        Init_book();
    }
    else Load();
    Menu_select();
}

运行截图:
在这里插入图片描述
在这里插入图片描述在这里插入图片描述
课设说明书我后续会上传到附件里,当然仅供大家参考啊哈哈哈~
大概是酱紫:
在这里插入图片描述Java课设的代码和文档等我开学了在写吧哈哈,最近忙着复习(预习?),因为疫情的原因,开学即考试!我太难了~
大家有什么问题可以私信我~

  • 77
    点赞
  • 626
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
用C++语言实现图书管理系统 摘 要 图书管理系统主要是对图书的录入、读者借阅、读者归还等功能进行实现。本课程设计 的系统开发平台为Windows XP,程序设计语言为C++,程序运行平台为Windws98/2000/XP/Seven。在程序设计中采用 了B-树方法提高书籍的查找速度。 关键词 程序设计;图书管理系统; C++;数据结构;B-树 1 索引 1.1课程设计目的 设计一个小型的图书管理系统,可以实现新增图书,读者借阅,读者归还等功能。 1.2.系统性能要求 能较快的查到所要查找的图书;能准确统计当前每种书的库存,以确定此书是否可以外 借;并且对外借的图书进行管理,记录借出时间、应还时间等。 1.3.功能的实现 1) 新书入库:确定书号后,登记到图书帐目表中,如果表中已有,则只将库存量增加; 2) 借阅:如果一种书的现存量大于0,则借出一本,登记借阅者的书证号和归还期限,改变 现存量; 3)归还:注销对借阅者的登记,改变该书的现存量。 2 系统详细设计及实现 1.所用的知识体系 在整个程序的设计过程当中,用到了C++的一些基础知识,面向对象的思想和结构化 的程序设计思想。数据结构的B-树建立索引,用索引提高查找的效率等。 2.系统功能组成框图 3 . 系统功能模块划分 " " 摸块保称 "功能说明 " "1 "系统管理 "显示库存,借阅,归还 " "2 "图书管理 "图书的添加,查询等操作 " "3 "借还书管理 "对每次借书信息的添加,删除等操作 " 4.流程图 4.1录入图书信息 4.2借阅图书 4.3归还图书 5 功能实现 5.1 运行程序的主界面 图5—1 操作界面 5.2 新书入库功能的操作界面 图5-2新书入库 5.3 查询数据的界面 图5-3查询书籍 5.4 查询所有书籍的界面 图 5-4显示库存 5.5 图书借阅的界面 图5-5借阅书籍 5.6 还书的界面 图5-6还书 3 参考文献 [1] 谭浩强 C语言设计(第三版)清华大学出版社 [2] 严蔚敏 吴伟民 数据结构(C语言版) 清华大学出版社 [3] 谭浩强 C++ 程序设计清华大学出版社 [4]参考网址http://www.php.net/manual/zh/function.fopen.php [5]参考网址http://hi.baidu.com/%B3%D5%B3%D5%B5%C4145/blog/item/48f2b1ed1d99d 1d2b21cb15c.html 附录 #include<stdio.h> #include<stdlib.h> #include<string.h> #include<conio.h> #include<time.h> //定义局变量 #define N 10000 //表示状态的字段 #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define INFEASIBLE -1 #define OVERFLOW -2 typedef int Status; typedef char *string ; #define m 3 //B-树的阶,设为 // 借阅者的结构体 typedef struct User{ unsigned int number; //借书证号码 int year; int month; int day; //借书时间 int dyear; //截至日期的年 int dmonth; //截至日期的月 int dday; //截至日期的日 struct User *next; //下一个借阅者 }User; //定义用户的的信息 //书的结构体 struct Book{ unsigned int key; //图书的书号 char bname[20]; // 书名 char writter[20]; // 著者 unsigned int left; // 现存量 unsigned int total; // 总存量 User *user; //借阅该书的人 }b[N]; //定义书的信息 //B- 树的存储结构 typedef Book KeyType; typedef struct BTNode{ int keynum; //结点中关键字个数,即结点的大小 struct BTNode *parent; //指向双亲结点 KeyType key[m + 1]; //关键字向量,号单元未用 struct BTNode *ptr[m + 1]; //子树指针向量 }BTNode,*BTree; //查找结果的存储结构体 typedef struct{ BTNode *pt; //指向找到的结点 int i; //1……m,在结

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值