收藏 分销(赏)

图书信息管理系统课程设计报告C语言程序设计.doc

上传人:二*** 文档编号:4511608 上传时间:2024-09-26 格式:DOC 页数:38 大小:113KB
下载 相关 举报
图书信息管理系统课程设计报告C语言程序设计.doc_第1页
第1页 / 共38页
亲,该文档总共38页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

1、. .学院计算机系课程设计报告实习名称 程序设计课程设计 设计题目 图书信息管理系统 实习时间2021.06.27-2021.07.04专业班级 网络工程 指导教师教学单位盖章 小组分工情况:学号XX分工二O一O年七月五日课程设计报告正文容及格式要求:1、正文局部主要包括:选题背景、论点或案论证、过程(设计或实验)论述、结果分析、结论或总结。2、标题:题目用小二号黑体字(加黑),居中;副标题用三号黑体字,紧挨正标题下居中,文字前加破折号。英文题目为18磅加粗Times New Roman字,副标题为16磅加粗Times New Roman字。3、课程设计报告格式要求:一级标题用小三号黑体字;二

2、级标题用四号黑体字;三级标题用小四号黑体字;正文用宋体小四号字英文用12磅Times New Roman字,采用1.5倍行距,标准字符间距:页码一律用小5号字标明。4、课程设计报告撰写要求:1文字通顺,语言流畅,能将设计过程表述清楚。2图表整洁,布局合理,须按规定的绘图标准绘制。3报告字数不少于3千字。C语言程序设计报告-图书管理系统一、实验准备做系统前,首先,自己详细看了?C程序设计教程?教科书的第十章?文件?,根本自学会了文件的相关容,理解了相关函数的用法和作用;另,上网查询了很多相关资料,还有找了很多相关的系统,都详细的看了一遍,加深了对C的理解以及对文件的相关容进一步理解。学习了C语言

3、的容,图书信息管理系统有助于C语言学习的进一步稳固,在本系统可以增强对指针、数组、文件、函数等根本知识的进一步理解。另外图书信息管理系统也是学校常用的根本系统之一,它有助于学校对图书馆书籍的根本管理。二、功能简介 图书信息管理系统是对图书信息的根本管理,它包括:图书信息的输入、图书信息的修改及删除、图书信息的查询、图书信息的添加、图书信息的浏览。使用模块化编程的法每项功能有一个或多个函数组合来完成.三、系统与性环境系统可以在MicrosoftVisualC+6.0软件运行,硬件根本无要求,现在的计算机根本都可以运行该系统。四、功能划分及详细说明主要算法的设计:(1) 主函数的算法设计开场输入选

4、择退出图书信息浏览函数图书信息查询函数图书信息修改函数图书信息输入函数完毕首先,运行程序,进入菜单,然后选择操作运用swith语句,调用各子函数。在返回操作中运用while语句进展控制返回菜单。(2) 各子函数的算法设计1、图书信息的输入函数开场语句语句和输入函数保存函数For函数返回函数完毕假真2、图书信息的修改开场读入函数输入函数是否相等输出信息选择表达式资料1资料2料2资料3资料4资料5资料6资料7选择返回主菜单完毕3、图书信息的查询void search()选择查询式 ,1按书号查询,2按书名查询, 然后定位,再调用输出函数;4、图书信息的浏览开场输出函数完毕返回主菜单 首先,输出所有

5、图书的信息,并输出图书记录数,然后调用辅助函数进展菜单项选择择,操作完成后返回主菜单。5、图书信息的添加开场输入要添加的本数输入函数保存函数返回函数完毕首先,从文件中调用函数读入函数,再输入要添加数,然后添加图书信息,并保存。上机调试过程:在调试过程中出现了多的错误!特别是在查询、修改删除这2个函数的调上花费了很多时间,主要是文件的写入与读出以及菜单调试的问题,还有建立新的也出现问题,说明自己对程序的执行过程理解不够深刻。五、源程序#include#include#include#include#define LEN sizeof(stu)typedef struct student long

6、 number; char name10; char sex3; int age; float chinese;float math; float english; float sum; float average; struct student *next;stu;book *creat(void);book *changes(book *head);book *modify(book *head,long num);book *del(book *head,long num);book *insert(book *head,book *stud);book *input(book *hea

7、d,book *p1);void sort(book *head);void total_average_sort(book *head);void chinese_sort(book *head);void math_sort(book *head);void english_sort(book *head);void print(book *head);void Statistics(book *head);void search(book *head);void numsearch(book *head,long num);void namesearch(book *head,char

8、name);int n;book *creat(void)book *head,*p1,*p2; n=0; p1=p2=(book *)malloc(LEN); printf(请输入图书信息!n);head=NULL; p1=input(head,p1); while(p1-number!=0) n=n+1; if(n=1) head=p1; else p2-next=p1; p2=p1; p1=(book *)malloc(LEN); p1=input(head,p1); p2-next=NULL; return(head);book *input(book *head,book *p1)/

9、*输入图书的信息*/int i,f,k;book *p2; loop:printf(图书号为整数,输入0时返回上一级:); scanf(%ld,&p1-number); if(p1-numbernumber=0) return(p1); else p2=head; f=0; for(i=1;inumber=p2-number) f=1;break; p2=p2-next; if(f) printf(图书不能重复,请重新输入!n);goto loop; printf(书名:); scanf(%s,p1-name); loop1:printf(类别: 1.文科 2.理科 n);printf(请选择

10、类别:); scanf(%d,&k);switch(k)case 1:strcpy(p1-sex,文科);break;case 2:strcpy(p1-sex,理科);break;default:printf(类别只能是“文科或“理科,请重新输入!n);goto loop1; printf(存期:); scanf(%d,&p1-age); while(p1-ageage120) printf(你输入的存期不符合实际情况,请重新输入!n);printf(存期:); scanf(%d,&p1-age); printf(章数:); scanf(%f,&p1-chinese);while(p1-chi

11、nesechinese100) printf(你输入的章数不符合实际情况,请重新输入!n); printf(章数:); scanf(%f,&p1-chinese); printf(页数:); scanf(%f,&p1-math);while(p1-mathmath100) printf(你输入的页数不符合实际情况,请重新输入!n); printf(页数:); scanf(%f,&p1-math); printf(阅读次数:); scanf(%f,&p1-english);while(p1-englishenglish100) printf(你输入的阅读次数不符合实际情况,请重新输入!n); p

12、rintf(阅读次数:); scanf(%f,&p1-english); p1-sum=p1-chinese+p1-math+p1-english; p1-average=p1-sum/3; return(p1);void search(book *head) int k; long num; char name10; if(n=0)printf(数据库为空,没有图书的记录!n);return; else do printf(1. 按书号查找 2. 按书名查找 0. 返回上一级n); printf(请选择:); scanf(%d,&k); switch(k) case 1:do printf(

13、书号输入0时跳出按书号查找:); scanf(%ld,&num); if(num=0)break; else if(num0) numsearch(head,num); else printf(输入错误,请重新选择!n); while(1); break; case 2:do printf(书名输入0时跳出按书名查找:); scanf(%s,name); printf(书号t书名t类别t存期t章数t页数t阅读次数t总次数t平均次数n); namesearch(head,name); while(strcmp(name,0)!=0); break; case 0:break; default:p

14、rintf(输入错误,请重新选择!n); while(k!=0);void numsearch(book *head,long num)book *p1; p1=head; while(p1!=NULL) if(num=p1-number) printf(书号t书名t类别t存期t章数t页数t阅读次数t总次数t平均次数n); printf(%ldt%st%st%dt%.1ft%.1ft%.1ft%.1ft%.1fn,p1-number,p1-name,p1-sex,p1-age,p1-chinese,p1-math,p1-english,p1-sum,p1-average); return; p

15、1=p1-next; printf(没有找到你要查找的图书信息!n);void namesearch(book *head,char name)int a=1;book *p1; p1=head; while(p1!=NULL) if(strcmp(name,p1-name)=0) printf(%ldt%st%st%dt%.1ft%.1ft%.1ft%.1ft%.1fn,p1-number,p1-name,p1-sex,p1-age,p1-chinese,p1-math,p1-english,p1-sum,p1-average);a=0; p1=p1-next;if(a) printf(没有

16、找到你要查找的图书信息!n);book *changes(book *head)book *p1; int k; long num; do printf(1. 修改 2. 删除 3. 插入 0. 返回上一级n); printf(请选择:); scanf(%d,&k); switch(k) case 1:do if(n=0) printf(数据库为空,没有图书的记录!n);break; else printf(请输入图书的书号书号应为整数,输入0时跳出修改数据:); scanf(%ld,&num); if(num=0)break; else if(num0) head=modify(head,n

17、um); else printf(书号不能为负数,请重新输入!n); while(1); break; case 2:do if(n=0)printf(数据库为空,没有图书信息!n);break; else printf(请输入要删除的图书的书号书号应为整数,输入0时跳出删除元素:); scanf(%ld,&num); if(num=0)break; else if(num0) head=del(head,num); else printf(书号不能为负数,请重新输入!n); while(1); break; case 3:printf(请输入图书信息!n); p1=(book *)mallo

18、c(LEN); p1=input(head,p1); while(p1-number!=0) head=insert(head,p1); print(head); printf(请输入图书信息!n); p1=(book *)malloc(LEN); p1=input(head,p1); break; case 0:break; default:printf(输入错误,请重新输入!n);while(k!=0); return(head);void sort(book *head)int k; if(n=0)printf(数据库为空,没有图书记录!n);return;do printf(1.按书号

19、排序 2.按总次数和平均次数排序 3.按章数成绩排序 4.按页数排序 5.按阅读次数排序 0.返回上一级n); printf(请选择:); scanf(%d,&k); switch(k) case 1:print(head);break; case 2:total_average_sort(head);break; case 3:chinese_sort(head);break; case 4:math_sort(head);break; case 5:english_sort(head);break; case 0:break; default:printf(输入错误,请重新输入!n); w

20、hile(k!=0);void total_average_sort(book *head)book *p1,*p2;int j=0;float max,k=301;printf(书号t书名t类别t存期t章数t页数t阅读次数t总次数t平均次数n);do max=0; for(p1=head;p1;p1=p1-next) if(p1-summax&p1-sumsum; p2=p1; k=max; for(p1=p2;p1;p1=p1-next) if(p1-sum=max) printf(%ldt%st%st%dt%.1ft%.1ft%.1ft%.1ft%.1fn,p1-number,p1-na

21、me,p1-sex,p1-age,p1-chinese,p1-math,p1-english,p1-sum,p1-average); j+;while(jnext) if(p1-chinesemax&p1-chinesechinese; p2=p1; k=max; for(p1=p2;p1;p1=p1-next) if(p1-chinese=max) printf(%ldt%st%st%dt%.1ft%.1ft%.1ft%.1ft%.1fn,p1-number,p1-name,p1-sex,p1-age,p1-chinese,p1-math,p1-english,p1-sum,p1-avera

22、ge); j+;while(jnext) if(p1-mathmax&p1-mathmath; p2=p1; k=max; for(p1=p2;p1;p1=p1-next) if(p1-math=max) printf(%ldt%st%st%dt%.1ft%.1ft%.1ft%.1ft%.1fn,p1-number,p1-name,p1-sex,p1-age,p1-chinese,p1-math,p1-english,p1-sum,p1-average); j+;while(jnext) if(p1-englishmax&p1-englishenglish; p2=p1; k=max; for

23、(p1=p2;p1;p1=p1-next) if(p1-english=max) printf(%ldt%st%st%dt%.1ft%.1ft%.1ft%.1ft%.1fn,p1-number,p1-name,p1-sex,p1-age,p1-chinese,p1-math,p1-english,p1-sum,p1-average); j+;while(jnumber=num) break; p1=p1-next; if(p1-number=num) do printf(1.书名 2.类别 3.存期 4.章数成绩 5.页数 6.阅读次数 0.返回上一级n); printf(请选择:); sca

24、nf(%d,&k); switch(k) case 1:printf(书名:);scanf(%s,p1-name);printf(修改成功!n);break; case 2:loop2:printf(类别: 1.文科 2. 理科n); printf(请选择类别:); scanf(%d,&m); switch(m) case 1:strcpy(p1-sex,文科);break; case 2:strcpy(p1-sex, 理科);break; default:printf(类别只能是“文科或“ 理科,请重新输入!n);goto loop2; printf(修改成功!n); break; case

25、 3:printf(存期:); scanf(%d,&p1-age); while(p1-ageage120) printf(你输入的存期不符合实际情况,请重新输入!n); printf(存期:); scanf(%d,&p1-age); printf(修改成功!n); break; case 4:printf(章数成绩:); scanf(%f,&p1-chinese); while(p1-chinesechinese100) printf(你输入的章数成绩不符合实际情况,请重新输入!n); printf(章数成绩:); scanf(%f,&p1-chinese); p1-sum=p1-chine

26、se+p1-math+p1-english; p1-average=p1-sum/3; printf(修改成功!n); break; case 5:printf(页数:); scanf(%f,&p1-math); while(p1-mathmath100) printf(你输入的页数不符合实际情况,请重新输入!n); printf(页数:); scanf(%f,&p1-math); p1-sum=p1-chinese+p1-math+p1-english; p1-average=p1-sum/3; printf(修改成功!n); break; case 6:printf(阅读次数:); sca

27、nf(%f,&p1-english); while(p1-englishenglish100) printf(年输入的阅读次数不符合实际情况,请重新输入!n); printf(阅读次数:); scanf(%f,&p1-english); p1-sum=p1-chinese+p1-math+p1-english; p1-average=p1-sum/3; printf(修改成功!n);break; case 0:break; default:printf(输入错误,请重新选择!n); while(k!=0); else printf(没有找到你要修改的图书的信息!n); return(head)

28、;book *del(book *head,long num)book *p1,*p2; if(head=NULL)printf(数据库为空,没有图书记录! n);goto end; p1=head; while(num!=p1-number&p1-next!=NULL) p2=p1;p1=p1-next; if(num=p1-number) if(p1=head)head=p1-next;printf(删除成功!n); else p2-next=p1-next;printf(删除成功!n); n=n-1; else printf(没有找到你要删除的图书信息!n,num); end:; ret

29、urn(head);book *insert(book *head,book *stud)book *p0,*p1,*p2; p1=head; p0=stud; if(head=NULL)head=p0;p0-next=NULL; elsewhile(p0-numberp1-number)&(p1-next!=NULL) p2=p1; p1=p1-next; if(p0-numbernumber) if(head=p1)head=p0; else p2-next=p0; p0-next=p1; else p1-next=p0;p0-next=NULL; n=n+1; return(head);

30、void Statistics(book *head)book *p1; int i,c=0,m=0,e=0; float cmax=0,mmax=0,emax=0,summax=0,averagemax=0; p1=head; for(i=1;ichinese=cmax) cmax=p1-chinese; if(p1-math=mmax) mmax=p1-math; if(p1-english=emax) emax=p1-english; if(p1-sum=summax) summax=p1-sum; if(p1-average=averagemax) averagemax=p1-aver

31、age; if(p1-chinesemathenglishnext; printf(总成绩最高分:%5.1fn,summax); printf(平成绩最高分:%5.1fn,averagemax); printf(章数最多:%5.1fn,cmax); printf(页数最高分:%5.1fn,mmax); printf(阅读次数最多:%5.1fn,emax); printf(章数最少:%dn,c); printf(页数最少:%dn,m); printf(阅读次数最少:%dn,e); printf(n);void print(book *head)book *p1; printf(n现在的%d个图书记录为:n,n); p1=head; if(head!=NULL) printf(书号t书名t类别t存期t章数t页数t阅读次数t总次数t平均次数n); do

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 学术论文 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服