大二上学期实训 图书管理系统

#include <stdio.h>//标准输入输出头文件  
#include <string.h>//字符串处理  
#include <Stdlib.h>//标准库头文件  
#define MAXSIZE 100  //最大值定义为100  
#define LIST_INIT_SIZE 100//图书证使用者最大值定义为100  
#include "tushu.h"  
/********************************************************* 
*功能描述:初始化图书信息 
*输入参数: 
*输出参数: 
*返回值: 
*其它说明: 
**********************************************************/  
void InitBo(ook &boo)  
{  
    for(int i=0; i<MAXSIZE; i++)  
    {  
        boo[i].NowNum=0;  
        boo[i].TotNum=0;  
        boo[i].next=NULL;  
    }  
}  
/********************************************************* 
*功能描述:初始化借阅者信息 
*输入参数: 
*输出参数: 
*返回值: 
*其它说明: 
**********************************************************/  
void InitRe(lend &Lin)  
{  
    for(int i=0; i<LIST_INIT_SIZE; i++)  
        Lin[i].next=NULL;  
}  
/********************************************************* 
*功能描述:折半(二分法)查找比较书号 
*输入参数:书号 
*输出参数: 
*返回值:ture  or  false 
*其它说明: 
**********************************************************/  
//用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置  
//外部函数mid,用来返回查找到的位置  
int mid=0;  
bool BinarySearch(ook boo,char SearchNum[])  
{  
    int low=0,high=total-1;  
    int found=0;  
    while(low<=high)  
    {  
        mid=(low+high)/2; //中间点  
        if(strcmp(boo[mid].num,SearchNum)==0) //书号相同  
        {  
            found=1;  
            return true;  
        }//查找成功  
        if(strcmp(boo[mid].num,SearchNum)!=0)//书号不同  
            high=mid-1;  
        else  low=mid+1;  
    }  
    if(found==0)  
        return false; //查找失败  
}  
//第一部分  
/********************************************************* 
*功能描述:添加新的图书信息 
*输入参数:图书信息 
*输出参数:入库后的图书信息 
*返回值: 
*其它说明: 
**********************************************************/  
void New(ook &boo, char BuyNum[])  
{  
    if(BinarySearch(boo,BuyNum))   //如果书库中有此书  
    {  
        boo[mid].TotNum++;              //总库存加1  
        boo[mid].NowNum++;              //现库存加1  
        printf("已成功存入图书库.\n");  
        printf("已更改书库中该书的信息.\n");  
    }  
    if(!BinarySearch(boo,BuyNum))  
    {  
        int i;  
        for(i=total; i>mid&&total; i--) //插在适合位置 保持有序  
            boo[i]=boo[i-1];                //空出插入位置  
  
        printf("                           请输入存入图书的信息                               \n");  
        strcpy(boo[i].num,BuyNum);  
        printf("需入库数量:");  
        scanf(" %d",&boo[i].NowNum);  
        boo[i].TotNum=boo[i].NowNum;  
        printf("书籍名字:");  
        scanf(" %s",&boo[i].name);  
        printf("图书作者:");  
        scanf(" %s",&boo[i].auth);  
        printf("图书出版社:");  
        scanf(" %s",&boo[i].pub);//补全信息  
        boo[i].next=NULL;  
        total++;//总量+1  
        printf("****************************************************************\n");  
        printf(" 书号      书名       作者       出版社       现有量    图书总数\n");  
        printf("****************************************************************\n");  
        printf("%3s%10s%11s%13s%13d%10d\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].NowNum,boo[mid].TotNum);  
        printf("****************************************************************\n");  
        printf("已成功存入书库.\n");  
    }  
}  
//第二部分  
/********************************************************* 
*功能描述:清空库存:某一种书已无保留价值,将它从图书账目中注销 
*输入参数:删除的图书书号 
*输出参数:是否已删除 
*返回值: 
*其它说明: 
**********************************************************/  
void Delete(ook &boo,char DeleteNum[])  
{  
    if(BinarySearch(boo,DeleteNum)==false||total==0)   //如果无此书  
        printf("书库中没有该书.\n");  
    if(BinarySearch(boo,DeleteNum))//若有  
    {  
        if(!boo[mid].next)  
        {  
            int j;  
            for( j=mid; j<total; j++)  
                boo[j]=boo[j+1];  
  
            strcpy(boo[j].num,boo[j+1].num);  
            strcpy(boo[j].name,boo[j+1].name);  
            strcpy(boo[j].auth,boo[j+1].auth);  
            strcpy(boo[j].pub,boo[j+1].pub);  
            boo[j].TotNum=boo[j+1].TotNum;  
            boo[j].NowNum=boo[j+1].NowNum;  
            printf("已成功删除该书.\n");  
        }  
        else printf("该书有借阅者,无法删除。\n");  
    }  
}  
//第三部分  
/********************************************************* 
*功能描述:借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, 
*           并登记借阅者的图书证号和归还期限 
*输入参数:图书的书号 
*输出参数:图书证号、借阅是否成功、归还日期 
*返回值: 
*其它说明: 
**********************************************************/  
void BookBorrow(ook &boo,lend &Lin,char BorrowNum[],char CaNum[])  
{  
    Bor *p,*q;  
    LinkList *m,*n;  
    if(!BinarySearch(boo,BorrowNum)||total==0) //如果没有找到此书  
        printf("书库里现在没有这本书哦~我们会根据需要采购的@-@\n");//如果有这书  
  
    if(BinarySearch(boo,BorrowNum))       //书库里有  
    {  
        if(boo[mid].NowNum>0)  //看现库存是否大于0  
        {  
            boo[mid].NowNum--;//借出一本,少1  
            if(boo[mid].next==NULL)  //若该书信息下显示该种书还没被人借过  
            {  
                m=(LinkList *)malloc(sizeof(LNode));//分配  
                boo[mid].next=m;//该图书信息中的链表 的第一个结点  
                strcpy(m->CardNum,CaNum);  
                m->next=NULL;//后一个结点为空  
            }  
            else    //如果已经有人在借这书了  
            {  
                m=boo[mid].next;  
                while(m->next) //遍历到最后一个结点  
                    m=m->next;  
                n=(LinkList *)malloc(sizeof(LNode));//分配空间,增加1个结点  
                m->next=n;  
                strcpy(n->CardNum,CaNum);//记录证号  
                n->next=NULL;  
            }  
            int i=0;  
            for(i=0; i<Retotal; i++) //  
            {  
                if(!strcmp(Lin[i].CNum,CaNum))//如果已经有该图书证的信息  
                {  
                    p=Lin[i].next;  
                    while(p->next)p=p->next;//遍历到最后一个结点  
                    q=(Bor *)malloc(sizeof(Boro));//分配空间  
                    p->next=q;  
                    strcpy(q->BNum,BorrowNum);    //记录书号  
                    printf("输入归还日期:");  
                    scanf("%s",&q->RetDate);  
                    q->next=NULL;  
                    printf("借阅成功.\n");  
  
                    break;  //找到证了就跳出循环  
                }  
            }  
            printf("借阅成功.\n");  
            if(i==Retotal)//如果没有这张证的信息  
            {  
                strcpy(Lin[i].CNum,CaNum); //记录证号  
                p=(Bor *)malloc(sizeof(Boro)); //分配空间  
                Lin[i].next=p;  
                strcpy(p->BNum,BorrowNum);  
                printf("输入归还日期:");  
                scanf(" %s",&p->RetDate);  
                p->next=NULL;  
                Retotal++;                //借阅证号信息总数加1  
                printf("借阅成功.\n");  
            }  
        }  
        else printf("借阅失败.该书现在库存为0.\n");  
    }  
}  
//第四部分  
/********************************************************* 
*功能描述:归还:注销对借阅者的登记,改变该书的现存量 
*输入参数:图书的书号 
*输出参数:是否成功归还 
*返回值: 
*其它说明: 
**********************************************************/  
void BookReturn(ook &boo,lend &Lin,char ReturnNum[],char BorrowerNum[])  
{  
    Bor *p,*q;  
    LinkList *m,*n;  
    int flag=0;//设置一个参数  
    if(!BinarySearch(boo,ReturnNum)||!total)   //没书  
        printf("书库中无此书.\n");  
    if(BinarySearch(boo,ReturnNum))       //有书  
    {  
        m=boo[mid].next;  
        if(!strcmp(m->CardNum,BorrowerNum))  //如果是第一个借的人还的  
        {  
            boo[mid].NowNum++;              //现库存加1  
            boo[mid].next=m->next;           //删除结点  
            free(m);                       //释放该结点的空间空间  
        }  
        else  
        {  
            while(m->next)      //查找归还者的借阅者结点  
            {  
                if(!strcmp(m->next->CardNum,BorrowerNum)) //如果找到  
                {  
                    n=m->next;         //n为归还者的借阅结点  
                    m->next=n->next;   //m指向归还者的借阅结点的下一结点  
                    free(n);           //释放空间  
                    boo[mid].NowNum++;  //现库存加1  
                    break;  
                }  
                m=m->next;  
            }  
        }  
    }  
//在借阅者表里查找借阅者信息  
    for(int i=0; i<Retotal; i++)  
    {  
        if(!strcmp(Lin[i].CNum,BorrowerNum))   //如果找到借阅者  
        {  
            p=Lin[i].next;  
            if(!strcmp(p->BNum,ReturnNum)) //如果是归还的是借的第一本书  
            {  
                Lin[i].next=p->next;   //指向下一借书结点  
                free(p);             //释放结点空间  
                printf("成功归还该书.\n");  
                flag=1;  
                break;  
            }  
            else  //找不到  
            {  
                while(p->next)      //找到归还书的借书结点  
                {  
                    if(!strcmp(p->next->BNum,ReturnNum)) //如果找到  
                    {  
                        q=p->next;  //q为归还书的借书结点  
                        p->next=q->next; //p指向下一借书结点  
                        free(q);    //释放空间  
                        printf("成功归还该书.\n");  
                        flag=1;  
                        break;  
                    }  
                    p=p->next;  
                }  
            }  
        }  
    }  
    for(int k=0; k<Retotal; k++)  
        if(!Lin[k].next)  
        {  
            int j;  
            for(j=k; j<Retotal; j++)  
                Lin[j]=Lin[j+1];         //其后都往前移一位,覆盖掉当前信息  
            strcpy(Lin[j].CNum,"               "); //删除图书证号  
            Retotal--;              //图书证数减1  
        }  //删除当前状态下没借书的图书证的信息,节省空间  
    if(flag==0)  printf("无该证信息.\n");  
}  
  
//第五部分  
/********************************************************* 
*功能描述:查找图书:实现按三种查询条件之一查找:按书号查找、 
*按作者查找。注:可不实现组合查找,即几个条件组合查找。 
*          根据书号查找 
*输入参数:图书书号 
*输出参数:相关信息 
*返回值: 
*其它说明: 
**********************************************************/  
void NumberSearch(ook &boo,char SeaNum[])  
{  
    LinkList *p;  
    p=boo[mid].next;  
    if(BinarySearch(boo,SeaNum)==false)printf("对不起,未找到您想查找的书。\n");//二分查找 没找到  
    else//找到了的话  
    {  
        {  
            printf("━━━━━━━━━━━━━━━━━━━━━━━━━━\n");  
            printf("书名                  作者               现库存     \n");  
            printf("━━━━━━━━━━━━━━━━━━━━━━━━━━\n");  
            printf("%3s%21s%22d\n",boo[mid].name,boo[mid].auth,boo[mid].NowNum);  
            printf("━━━━━━━━━━━━━━━━━━━━━━━━━━\n");  
            if(boo[mid].next!=NULL)  
            {  
  
                printf("  已借该书的图书证号:    \n");  
                while(p)  
                {  
                    printf(p->CardNum);  
                    p=p->next;  
                }  
            }  
        }  
        while(p)  
        {  
            printf(" %s   ",p->CardNum);//在按书号查找的函数里也显示借了这本书的借阅者的证号  
            p=p->next;  
        }  
        printf(" \n");  
    }//显示查找的书籍的信息  
}  
/********************************************************* 
*功能描述:根据作者查找 
*输入参数:图书的作者 
*输出参数:图书的相关信息 
*返回值: 
*其它说明: 
**********************************************************/  
void AuthorSearch(ook &boo)  
{  
  
    char SeaAuth[20];  
    printf("输入想查找的书的作者:\n");  
    scanf(" %s",&SeaAuth);  
    printf("找到符合该作者的书的详细信息如下:\n");  
    for(int i=0; i<total; i++)  
    {  
        if(strcmp(SeaAuth,boo[i].auth)==0)//如果作者一样  
        {  
  
            printf("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n");  
            printf(" 书号      书名       作者       出版社       现库存    \n");  
            printf("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n");  
            printf("%3s%10s%11s%13s%13d\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].NowNum);  
            printf("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n");  
        }//显示符合信息的所有书籍的信息  
    }  
}  
/********************************************************* 
*功能描述:菜单 
*输入参数:借书人的选择 
*输出参数:图书的相关信息 
*返回值: 
*其它说明: 
**********************************************************/  
void Menu()  
{  
    printf("                                 图书管理系统                                       \n");  
    printf("                                                                                    \n");  
    printf("                                                                                    \n");  
    printf("                      1. 新增图书       2. 删除图书                                 \n");  
    printf("                      3. 借阅图书       4. 归还图书                                 \n");  
    printf("                      5. 按书号查找     7. 按作者查找                               \n");  
    printf("                             0. 退出图书管理系统                         \n");  
    printf("                                                                                    \n");  
    printf("                                 你的选择?                                         \n");  
}  
/********************************************************* 
*功能描述:主函数 
*输入参数:各种选择 
*输出参数:实现各项功能 
*返回值: 
*其它说明: 
**********************************************************/  
int main()  
{  
    ook Bo;  
    lend Lin;  
    char BNum[20];  
    char CNum[20];  
    printf("                        欢 迎 进 入 图 书 管 理 系 统                         \n\n\n");  
    int choice=10;  
    int SearchCho=10,ViewCho=10;  
    while(choice!=0)  
    {  
        Menu();//显示菜单  
        scanf(" %d",&choice);  
        switch(choice)  
        {  
        //采编入库  
            case 1:  
            printf("请输入入库的书的书号:");  
            scanf(" %s",BNum);  
            New(Bo,BNum);  
            break;  
        //清空库存  
        case 2:  
            printf("请输入想要清除的书的书号:");  
            scanf(" %s",BNum);  
            Delete(Bo,BNum);  
            break;  
        //借阅  
        case 3:  
            printf("请输入想要借阅的书的书号:\n");  
            scanf(" %s",&BNum);  
            printf("请输入图书证号:");  
            scanf(" %s",&CNum);  
            BookBorrow(Bo,Lin,BNum,CNum);  
            break;  
        //归还  
        case 4:  
            printf("请输入想要归还的书的书号:\n");  
            scanf(" %s",&BNum);  
            printf("请输入图书证号:");  
            scanf(" %s",&CNum);  
            BookReturn(Bo,Lin,BNum,CNum);  
            break;  
        //查找根据书号查找  
        case 5:  
            printf("请输入书号:");//输入书号查找  
            scanf(" %s",&BNum);  
            NumberSearch(Bo,BNum);  
            break;  
  
        //根据作者查找  
        case 7:  
            AuthorSearch(Bo);  
            break;  
        //退出系统  
        case 0:  
            exit(0);  
            break;  
        default:  
            printf("输入错误!\n");  
            break;  
        }  
    }  
}  
(2)tushu.h
[cpp] view plain copy
/********************************************************* 
*版权所有(c)2014,sunjie 
* 
*文件名称:tushuguanli.c 
*文件标识:无 
*内容摘要:该代码用于满足后缀要求的第一个文件 
*其他说明:无 
*当前版本:v1.0 
*作者:孙洁 
*完成日期:2015.12.25 
* 
*修改记录1: 
*修改日期:2015.12.25 
*版本号:v1.0 

*修改内容:创建 
**********************************************************/  
#ifndef TUSHU_H_INCLUDED  
#define TUSHU_H_INCLUDED  
#include <stdio.h>  
#include <stdlib.h>  
#define MAXSIZE 100  //最大值定义为100  
#define LIST_INIT_SIZE 100//图书证使用者最大值定义为100  
//第一  
/********************************************************* 
*功能描述:借书人的链表 
            借书人要干什么 
*输入参数: 
*输出参数: 
*返回值: 
*其它说明: 
**********************************************************/  
typedef struct Boro  
{  
    char BNum[20];//借书的书号  
    char RetDate[8];//归还日期  
    struct Boro *next;//指向后继节点  
} Bor;  
//第二  
/********************************************************* 
*功能描述:图书的结构体信息 
*输入参数: 
*输出参数: 
*返回值: 
*其它说明: 
**********************************************************/  
typedef struct LinkBook  
{  
    Bor *next;//该图书证的借书行为  
    char CNum[20];//证号  
    int Total;//借书的数量  
} lend[LIST_INIT_SIZE]; //借书人数组  
//第三  
/********************************************************* 
*功能描述:借书人图书证号的链表 
*输入参数: 
*输出参数: 
*返回值: 
*其它说明: 
**********************************************************/  
typedef struct LNode  
{  
    char CardNum[20];//图书证号  
    struct LNode *next;  
} LinkList; //借书人  
//第四  
/********************************************************* 
*功能描述:每种图书需要登记的内容: 
           书号、书名、作者、出版社、总库存量和现库存量 
*输入参数: 
*输出参数: 
*返回值: 
*其它说明: 
**********************************************************/  
typedef struct book  
{  
  
    char num[20];//书号  
    char name[20];//书名  
    char auth[20];//作者  
    char pub[20];//出版社  
    int TotNum;//总库存  
    int NowNum;//现库存  
    LinkList *next;//借了该书的人  
} ook[MAXSIZE];  
//  
int Retotal;//读者数量  
int total; //定义外部变量.书的种类数  
  
#endif // TUSHU_H_INCLUDED  

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值