C语言是一门面向过程、抽象化的通用程序设计语言,广泛应用于底层开发。C语言能以简易的方式编译、处理低级存储器。C语言拥有一套完整的理论体系经过了漫长的发展历史,在编程语言中具有举足轻重的地位。
别着急离婚,你的婚姻还有救!做下情感测试,情感导师助你挽回
爱燃情感咨询
广告
相关视频
推腿的好处和作用
第一、可以起到按摩腿部肌肉的效果,使腿部肌肉力量几种,不容易受到外伤,同时也可以保护股骨头不受到压迫,但是要注意力度适中,避免过度用力引起肌肉酸痛。
文章
2020-07-17
救荒本草是哪个朝代的
明朝。《救荒本草》一部由是医学家朱橚,主持编写的植物图谱,于明永乐四年编写完成,是我国历史上最早的一部以救荒为宗旨的农学、植物学专著书。全书分上、 下两卷。记载植物414种,每种都配有精美的木刻插图。
文章
2020-07-17
保税区是什么意思
保税区是经国务院批准设立的、海关实施特殊监管的经济区域,是我国目前开放度和自由度最大的经济区域。其功能定位为保税仓储、出口加工、转口贸易三大功能。
文章
2020-07-17
实蛋和毛蛋的区别
实蛋是由鸡蛋打出的蛋液和食用碱搅拌而成的蛋液,倒入保存好的鸡蛋胚中,凝固而成的一种鸡蛋。毛鸡蛋是鸡蛋在孵化过程中受到不当的温度、湿度或者是某些病菌的影响,导致鸡胚发育停止,死在蛋壳内尚未成熟的小鸡。
文章
2020-07-17
爱人出轨了?不想离婚?你可以这样去挽回!
情感老师-欣悦老师
广告
lpr定价基准转换是什么意思
LPR就是包括四大行的在内的多家银行每月公布一个自己的贷款利率,然后以每家银行的贷款发放量占这些银行总贷款量的比例作为权重,求出一个加权平均数,这个数就是LPR,即市场贷款基准利率。
文章
2020-07-17
水果核属于什么垃圾
水果核属于湿垃圾。湿垃圾即易腐垃圾,主要包括:食材废料、剩菜剩饭、过期食品、瓜皮果核、花卉绿植、中药药渣等易腐的生物质生活废弃物。湿垃圾应从产生时就与其他品种垃圾分开收集,投放前尽量沥干水分。
文章
2020-07-17
郭守敬的主要贡献是什么方面
主要贡献是:参与制定了授时历。此书不但在天文数据上有巨大进步,而且在天文学的计算方法方面也有重大的创新。使用四海测验法结合改进、创造的天文仪器,进行了许多精密的天文观测,从而使授时历的编制有了可靠的观测基础。
文章
2020-07-17
三文鱼跟虹鳟区别
纹理和颜色。三文鱼:脂肪含量高,肉色偏橙黄、表面的白色花纹更白,线条较宽,且线条边缘比较模糊。虹鳟鱼:脂肪含量少,线条细而且边缘很硬,也就是红白相间很明显。
文章
2020-07-17
司法考试(8月22日起)重新调整,非法学专业需满足3大条件
柒贤教育
广告
7日年化收益率是什么意思
货币基金是以国债或票据为投资对象的一种基金。而七日年化收益率,就是属于货币基金的一个专业名词。它是以基金最近7日(含节假日)的收益,所折算出来的基金年收益率。
文章
2020-07-17
冒烟冷饮原理
它是运用零下196℃的液氮瞬间凝冻技术,食用液氮是无色,无味的液体,配合使原奶脂在短时间内凝冻成型。或者在液氮里浸泡拿出来就会冒烟了,真正的现场纯手工制作过程充满科技感、魔幻感。
文章
2020-07-17
这个不是我写的,但改改就能用。希望对你能有帮助。。。#include <stdio.h>
#include <string.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
{//每种图书需要登记的内容包括书号ISBN、书名、作者、出版社、总库存量和现库存量。
char num[20]//书号
char name[20]//书名
char auth[20]//作者
char pub[20]//出版社
int TotNum//总库存
int NowNum//现库存
LinkList *next//借了该书的人
}ook[MAXSIZE]
//
int Retotal//读者数量
int total//定义外部变量.书的种类数
//
//结构体初始化
void InitBo(ook &boo) //初始化图书信息
{
for(int i=0i<MAXSIZEi++)
{
boo[i].NowNum=0
boo[i].TotNum=0
boo[i].next=NULL
}
}
void InitRe(lend &Lin) //初始化借阅者信息
{
for(int i=0i<LIST_INIT_SIZEi++)
Lin[i].next=NULL
}
//
int mid=0//外部函数mid,用来返回查找到的位置
bool BinarySearch(ook boo,char SearchNum[]) //二分法查找比较书号
{ //用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置
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 Buy(ook &boo, char BuyNum[])
{//1、 采编入库:新购入一种书,如果该书在图书账目中已经存在,则将其库存量增加(包
//括总库存量和现库存量),如果该书不存在,则在图书账目中增加一种书,总库存量和现库存量均为1。
if(BinarySearch(boo,BuyNum)) //如果书库中有此书
{
boo[mid].TotNum++ //总库存加1
boo[mid].NowNum++ //现库存加1
printf("入库成功.\n")
printf("已更改书库中该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].TotNum,boo[mid].NowNum)
}
if(!BinarySearch(boo,BuyNum))
{
for(int i=totali>mid&&totali--) //插在适合位置 保持有序
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("已增加该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum)
printf("入库成功.\n")
}
}
void Delete(ook &boo,char DeleteNum[])
{//2、 清空库存:某一种书已无保留价值,将它从图书账目中注销。
if(BinarySearch(boo,DeleteNum)==false||total==0) //如果无此书
printf("书库中没有该书.\n")
if(BinarySearch(boo,DeleteNum))//若有
{
if(!boo[mid].next)
{
for(int j=midj<totalj++)
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")
}
}
void Borrow(ook &boo,lend &Lin,char BorrowNum[],char CaNum[])
{//3、 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1,
//并登记借阅者的图书证号和归还期限。
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=0i<Retotali++)//
{
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 //找到证了就跳出循环
}
}
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 Return(ook &boo,lend &Lin,char ReturnNum[],char BorrowerNum[])
{//4、 归还:注销对借阅者的登记,改变该书的现存量。
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=0i<Retotali++)
{
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=0k<Retotalk++)
if(!Lin[k].next)
{
for(int j=kj<Retotalj++)
Lin[j]=Lin[j+1]//其后都往前移一位,覆盖掉当前信息
strcpy(Lin[j].CNum," ")//删除图书证号
Retotal-- //图书证数减1
} //删除当前状态下没借书的图书证的信息,节省空间
if(flag==0) printf("无该证信息.\n")
}
//5、 查找:实现按三种查询条件之一查找:按书号查找、
//按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。
void SearchByNum(ook &boo,char SeaNum[])
{//BY NUM 根据书号查找
LinkList *p
p=boo[mid].next
if(BinarySearch(boo,SeaNum)==false)printf("对不起,未找到您想查找的书。\n")//二分查找 没找到
else//找到了的话
{
{
printf("┏━━━━━━━┳━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━┳━━━━━┓\n")
printf("┃ 书号 ┃ 书名 ┃ 作者 ┃ 出版社 ┃ 现库存 ┃ 总库存 ┃\n")
printf("┣━━━━━━━╋━━━━━━━╋━━━━━━━━╋━━━━━━━━╋━━━━━╋━━━━━┫\n")
printf("┃%14s┃%14s┃%16s┃%16s┃%10d┃%10d┃\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].NowNum,boo[mid].TotNum)
printf("┗━━━━━━━┻━━━━━━━┻━━━━━━━━┻━━━━━━━━┻━━━━━┻━━━━━┛\n")
if(boo[mid].next!=NULL)
{
printf("┏━━━━━━━┓\n")
printf("┃ 已借该书的 ┃\n")
printf("┃ 图书证号 ┃\n")
while(p)
{
printf("┣━━━━━━━┫\n")
printf("┃%14s┃\n",p->CardNum)
p=p->next
}
printf("┗━━━━━━━┛\n")
}
}
while(p)
{
printf(" %s ",p->CardNum)//在按书号查找的函数里也显示借了这本书的借阅者的证号
p=p->next
}
printf(" \n")
}//显示查找的书籍的信息
}
void SearchByName(ook &boo)
{//BY NAME 根据书名查找
char SeaName[20]
printf("输入想查找的书的书名:\n")
scanf(" %s",&SeaName)
printf("找到符合该书名的书的详细信息如下:\n")
for(int i=0i<totali++)
{
if(strcmp(SeaName,boo[i].name)==0)//如果书名一样
{
printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum)
}//显示符合信息的所有书籍的信息
}
}
void SearchByAuth(ook &boo)
{// BY AUTH 根据作者查找
char SeaAuth[20]
printf("输入想查找的书的作者:\n")
scanf(" %s",&SeaAuth)
printf("找到符合该作者的书的详细信息如下:\n")
for(int i=0i<totali++)
{
if(strcmp(SeaAuth,boo[i].auth)==0)//如果作者一样
{
printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum)
}//显示符合信息的所有书籍的信息
}
}
//6、 查看:可查看某图书证号的借阅者借阅的全部图书,可查看全部超期未还的图书。
void ViewCard(ook &boo,lend &Lin)
{//查看某图书证号的借阅者借阅的全部图书
char Num[20]
printf("请输入您所想要查看的图书证号:\n")
scanf(" %s",&Num)
Bor *p
int qqq=0
for(int i=0i<Retotali++)
{
if(strcmp(Lin[i].CNum,Num)==0) //找到该证
{
printf("这个证借的书有:\n")
p=Lin[i].next
while(p)
{
printf(" %s ",p->BNum) //书号
p=p->next
}
printf("\n")
qqq=1
break
}
}
if(qqq==0)
printf("该证不存在.\n")
}
void ViewBook(ook &boo,lend &Lin)
{//查看全部超期未还的图书
char date[8]
Bor *p
printf("请输入日期(请按格式20060605输入):\n")
scanf(" %s",&date)
printf("所有超期未还的书有:\n")
for(int i=0i<Retotali++)
{
p=Lin[i].next
while(p)//当p不空时
{
if(strcmp(p->RetDate,date)<0) //超过日期
{
printf("书号为 %s 证号为 %s应归还日期为 %s \n",p->BNum,Lin[i].CNum,p->RetDate)
}//显示所有超期未还的书的信息
p=p->next
}
}
}
void Menu() //菜单
{
printf("┏—————————————————M E N U————————————————┓\n")
printf("││\n")
printf("│ 1. 采编入库:新购入一种书,如果该书在图书账目中已经存在, │\n")
printf("│ 则将其库存量增加(包括总库存量和现库存量)。 │\n")
printf("│ 如果该书不存在,则在图书账目中增加一种书, │\n")
printf("│ 总库存量和现库存量均为输入的数字。 │\n")
printf("│ 2. 清空库存:某一种书已无保留价值,将它从图书账目中注销。 │\n")
printf("│ 3. 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1,│\n")
printf("│ 并登记借阅者的图书证号和归还期限。 │\n")
printf("│ 4. 归还:注销对借阅者的登记,改变该书的现存量。 │\n")
printf("│ 5. 按书号查找。 │\n")
printf("│ 6. 按书名查找。 │\n")
printf("│ 7. 按作者查找。 │\n")
printf("│ 8. 查看某图书证号的借阅者借阅的全部图书。 │\n")
printf("│ 9. 查看全部超期未还的图书。 │\n")
printf("│ 0. 退出图书管理系统。 │\n")
printf("││\n")
printf("┗—————————————请 选 择 你 需 要 的 操 作————————————┛\n")
}
void main()
{
ook Bo
lend Lin
char BNum[20]
char CNum[20]
printf("-----------------------欢 迎 进 入 图 书 管 理 系 统!---------------------------\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)
Buy(Bo,BNum)
break
case 2://清空库存
printf("请输入想要清除的书的书号:")
scanf(" %s",BNum)
Delete(Bo,BNum)
break
case 3://借阅
printf("请输入想要借阅的书的书号:\n")
scanf(" %s",&BNum)
printf("请输入图书证号:")
scanf(" %s",&CNum)
Borrow(Bo,Lin,BNum,CNum)
break
case 4://归还
printf("请输入想要归还的书的书号:\n")
scanf(" %s",&BNum)
printf("请输入图书证号:")
scanf(" %s",&CNum)
Return(Bo,Lin,BNum,CNum)
break
case 5://查找//根据书号查找
printf("请输入书号:")//输入书号查找
scanf(" %s",&BNum)
SearchByNum(Bo,BNum)
break
case 6://根据书名查找
SearchByName(Bo)
break
case 7://根据作者查找
SearchByAuth(Bo)
break
case 8://查看某图书证所借的所有书
ViewCard(Bo,Lin)
break
case 9: //查看全部超期未还的书
ViewBook(Bo,Lin)
break
case 0://退出系统
exit(0)break
default:printf("输入错误!\n")exit(0)break
}
}
}