借同学百度知道问的,求一个C语言课程设计,关于图书馆借阅的程序。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了借同学百度知道问的,求一个C语言课程设计,关于图书馆借阅的程序。相关的知识,希望对你有一定的参考价值。

图书借阅管理
设计要求
基本功能:
图书管理
读者管理
借书管理
还书管理
查询与统计
拓展功能:
图书管理、读者管理、借书管理及还书管理中的删除、修改功能。
创新(自拟)功能:
程序实现的其它功能由个人自拟。

设计要求具体说明
图书管理主要为添加图书,如图书一些基本信息输入。
读者管理主要为添加读者(即借书证),如读者一些基本信息输入。
借书管理包括借书时需输入借书日期、书号和借书证号。
还书管理包括还书时需输入还书日期、书号和借书证号。
以上这些信息均需写入文件,文件可以分成四个图书文件、读者文件、借书文件及还书文件。
图书查询:当输入书号,列出该图书的一些基本信息及该图书所借的读者。
读者查询:当输入借书证号、开始日期、结束日期,统计出该张借书证号在某一时期所借阅的图书情况等等。
统计图书书籍总数、已借出数据总数、在库书籍数等。
统计图书书籍总金额、书籍的平均价格。
拓展功能:
进行图书信息修改、图书删除,但是当该图书有在借时,不能删除。
读者信息修改、删除读者,但当是读者有图书在借时,不能删除。
找出借阅次数最多的10本书,并对它们进行排序。
统计借阅书籍最多的前5名读者。

设计提示
定义合适的结构体类型。每本书的基本信息书号、书名、作者、出版社。一张借书证所借的书的数量不限。

谢谢各位大大了……
这个礼拜天之前就要撒……谢谢各位了
EMAIL地址 dongdongks@126.com

这个不是我写的,但改改就能用。希望对你能有帮助。。。

#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=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;


//

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=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("已增加该书的信息。编号 %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=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");




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=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; //找到证了就跳出循环


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=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)

for(int j=k;j<Retotal;j++)
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=0;i<total;i++)

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=0;i<total;i++)

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=0;i<Retotal;i++)

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=0;i<Retotal;i++)

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;



参考技术A #include <stdio.h>
#include <stdlib.h>
#include <conio.h>

struct BOOK

int id,usr[10],total,store,days[10];
char name[31],author[21];
books[100];
/*上面是结构体的定义,用于存放书籍及借书的信息。*/

void page_title(char *menu_item)

clrscr();
printf(">>> 图 书 管 理 系 统 <<<\n\n- %s -\n\n",menu_item);

/*上面是打印页眉的函数,同时通过参数menu_item,可以显示当前的状态。*/

void return_confirm(void)

printf("\n按任意键返回……\n");
getch();

/*上面是返回前请求确认的函数,以便在返回前观察结果*/

int search_book(void)

int n,i;
printf("请输入图书序号:");
scanf("%d",&i);
for(n=0;n<100;n++)

if(books[n].id==i)

printf("书名:%s\n",books[n].name);
printf("作者:%s\n",books[n].author);
printf("存数:%d of ",books[n].store);
printf("%d\n",books[n].total);
return n;


printf("\n输入错误或无效图书序号.\n");
return -1;

/*上面的函数是在数组中找到图书号匹配的记录,显示其信息并返
回数组下标,如果找不到相应记录则提示错误并返回-1。*/

void book_out(void)

int n,s,l,d;
page_title("借阅图书");
if((n=search_book())!=-1&&books[n].store>0)

printf("请输入借书证序号:");
scanf("%d",&s);
printf("请输入可借天数:");
scanf("%d",&d);
for(l=0;l<10;l++)

if(books[n].usr[l]==0)

books[n].usr[l]=s;
books[n].days[l]=d;
break;


books[n].store--;

if(n!=-1&&books[n].store==0) printf("此书已经全部借出.\n");
return_confirm();

/*上面是借书的函数,首先调用找书函数*/

void book_in(void)

int n,s,l;
page_title("归还图书");
if((n=search_book())!=-1&&books[n].store<books[n].total)

printf("借阅者图书证列表:\n");
for(l=0;l<10;l++)
if (books[n].usr[l]!=0)
printf("[%d] - %d天\n",books[n].usr[l],books[n].days[l]);
printf("请输入借书证序号:");
scanf("%d",&s);
for(l=0;l<10;l++)

if(books[n].usr[l]==s)

books[n].usr[l]=0;
books[n].days[l]=0;
break;


books[n].store++;

if(n!=-1&&books[n].store==books[n].total)
printf("全部入藏.\n");
return_confirm();


void book_add(void)

int n;
page_title("注册新书");
for(n=0;n<100;n++)
if(books[n].id==0) break;
printf("序号:");
scanf("%d",&books[n].id);
printf("书名:");
scanf("%s",&books[n].name);
printf("作者:");
scanf("%s",&books[n].author);
printf("数量:");
scanf("%d",&books[n].total);
books[n].store=books[n].total;
return_confirm();

void book_del(void)

int n;
page_title("注销旧书");
if((n=search_book())!=-1) books[n].id=0;
printf("该书已注销.\n");
return_confirm();


void main(void)

menu: page_title("操作选单");
printf("请用数字键选择操作\n\n");
printf("1 借阅图书\n2 归还图书\n\n");
printf("3 注册新书\n4 注销旧书\n\n");
printf("\n0 退出\n");
switch(getch())

case '1' : book_out();break;
case '2' : book_in();break;
case '3' : book_add();break;
case '4' : book_del();break;
case '0' : exit(0);

goto menu;


int n;
page_title("广?症慕");
if((n=search_book())!=-1) books[n].id=0;
printf("乎慕厮广?.\n");
return_confirm();


void main(void)

menu: page_title("荷恬佥汽");
printf("萩喘方忖囚佥夲荷恬\n\n");
printf("1 処堋夕慕\n2 拷珊夕慕\n\n");
printf("3 广过仟慕\n4 广?症慕\n\n");
printf("\n0 曜竃\n");
switch(getch())

case '1' : book_out();break;
case '2' : book_in();break;
case '3' : book_add();break;
case '4' : book_del();break;
case '0' : exit(0);

goto menu;
本回答被提问者采纳
参考技术B 借同学百度知道问的,求一个C语言课程设计,关于图书馆借阅的程序。
论文素材集锦

中国:

1.司马迁在遭受了腐刑之后,发愤继续撰写《史记》,并且终于完成了这部光辉著作。

2. 晋代著名书法家王曦之写字,用尽18缸水,终于成为一代书法大师.

3.李时珍花了31年功夫,读了800多种书籍,写了上千万字笔记,游历了7个省,收集了成千上万个单方,为了了解一些草药的解毒效果,吞服了一些剧烈的毒药,最后写成了中国医药学的辉煌巨著——《本草纲目》.

4.蒲松龄草亭问路。清代文学家蒲松龄在路边搭建茅草凉亭,记录过路行人所讲的故事,经过几十年如一日地辛勤搜集,加上自己废寝忘食的创作,终于完成了中国古代文学史上划时代的辉煌巨著《聊斋志异》。

5.张海迪 5 岁时因患脊髓血管瘤,高位截瘫,她因此没有进过学校,童年时就开始以顽强的毅力自学知识,她先后自学了小学、中学、大学的专业课程。1983 年,海迪走上了文学创作的道路,她以顽强的毅力克服疾病和困难,精益求精地进行创作,执着地为文学而战。

6.我国当代数学家陈景润,在攀登数学高峰的道路上,翻阅了国内外上千本有关资料,通宵达 旦地看书学习,演算研究,最后取得了震惊世界的成就,成为最接近数学王冠上的明珠—— 哥德巴赫猜想的第一人。

7.巴金在他年近八旬的时候,仍克服巨大的病痛,用坚强的毅力写完了五卷《随想录》,使他的散文创作在思想艺术上达到了一个高峰。

8.袁隆平一直从事农业教育及杂交水稻研究,为农业作出了巨大贡献,发表了水稻有杂交优势的观点,打破了世界性的自花授粉作物育种的禁区。国际上称袁隆平为“世界杂交水稻之父”。

9.一次次夺冠,郭晶晶是“后伏明霞时代”跳水世界的女一号;奥运会单人冠军是郭晶晶眼前的目标,人们期待着她能开创自己的“郭晶晶时代”。

少年的时 周恩来就立志为中华的崛起而读书

10.陈胜:年轻的时候就不满足于做一个佣耕者,有远大抱负,“燕雀安知鸿鹄之志哉?”,后领导了历史上第一次农民起义。

11.苏东坡披发仰天大呼“大江东去”,他面临的那些烦心琐事顷刻之间沉入滚滚波涛之中,消失得无影无踪。壮阔的滔滔江水让东坡选择忘记,忘记那些失意、悲伤,忘记那些仕途的不得意。

12.陶潜伴着“庄生晓梦迷蝴蝶”中的翩翩起舞的蝴蝶在东蓠之下悠然采菊。面对南山,渊明选择忘记,忘记那些官场的丑恶,忘记自己遇到的所有不快.

13.卓越的科学家李四光不信洋人信自己,靠自信、自强彻底粉碎了“中国贫油论”。

14我国当代著名国画大师李苦禅,为人重诺守信。他曾允诺一位老友索画的要求。后因生病和另一些事情牵扯,耽误了及时作画,后来他的那位老友突然病故,他闻讯后,后悔不已。立即挥毫作“百莲图”郑重地题款钤印。随后携画至后院,肃立焚烧,祭典亡灵。事后,他不无自丽地对儿子说:今后若再有老友索画,要及时提醒我,做人可不能失信啊!

15.周恩来严守纪律的事例很多,在革命战争年代,他和电子表颖超同志严守党的保密纪律的故事,早已传为佳话。即使在他当了总理以后,在日常生活中,他也是事事处处严守纪律。

16.明代抗倭名将戚继光,他所率领的戚家军,英勇善战。相继消灭浙江、福建、广东的倭寇,荡平东南沿海的多年倭患。后来又镇守北方,使塞外统治者不敢南犯。这一支使敌人闻风丧胆的精锐之师,主要是靠铁的纪律保证。

17.明代著名地理学家徐霞客,年轻时便立下“探奇于名山大川”的宏愿。后来多次遇险,几乎丧命,但他始终没有畏惧,最终给人留下了具有重大学术价值的《徐霞客游记》。

18.吴王夫差立志为父报仇,打败强国——楚国;贪图享乐,败于自己曾打败过的小国——越国。

19.李贺虽只活到27岁,但留下......
参考技术C printf("\t\t\t1. 输入学生成绩记录 Enter the record\n"); /*输入学生成绩记录*/
printf("\t\t\t2. 显示 Print the record\n"); /*显示*/
printf("\t\t\t3. 寻找 Search record on name\n"); /*寻找*/
printf("\t\t\t4. 删除 Delete a record\n"); /*删除*/
printf("\t\t\t5. 排序 Sort to make New a file\n"); /*排序*/
printf("\t\t\t6. 插入 Insert record to list\n"); /*插入*/
printf("\t\t\t7. 保存 Save the file\n"); /*保存*/
printf("\t\t\t8. 读取 Load the file\n"); /*读取*/
printf("\t\t\t9. 退出 Quit\n"); /*退出*/
参考技术D 借的百度号?

以上是关于借同学百度知道问的,求一个C语言课程设计,关于图书馆借阅的程序。的主要内容,如果未能解决你的问题,请参考以下文章

求图书馆管理系统程序(c语言)

c语言 数据结构课程设计 图书管理系统

用java图书销售管理系统的课程设计怎么做?

C语言图书管理借阅系统——ncurses库的使用

C语言课程设计"学生信息管理系统设计 "怎么做?

关于c语言课程设计链表的两个问题。。(高分求助) 非常急。。。。!!。