课 程 报 告
课 程 名 称: 程序设计实践 专 业 班 级 : 信息类1006 学 生 姓 名 :
学 号 : 201046830605 任 课 教 师 : 徐振强 学 期 :2010-2011学年第二学期
课程报告任务书
题 目 图书信息管理系统 开发一个图书信息管理系统,图书信息包括:图书编号、书名、作者、出版社、类别、出版时间、价格等基本信息(也可以根据自己情况进行扩充,比如是否借出、库存量等)。使之能提供以下基本功能: (1)图书信息录入功能(图书信息用文件保存)--输入 (2)图书信息浏览功能--输出 主要 (3)查询功能(至少一种查询方式)、排序功能(至少一种排序方式): ①按书名查询 ②按作者名查询 ③ 按照价钱排序 ④按出版时间排序等等 内容 (4)图书信息的删除与修改 扩展功能:可以按照自己的程度进行扩展。比如(1)简单的权限处理 (2)报表打印功能(3)甚至根据自己情况,可以加上学生信息,并扩充为图书借阅系统。(4)模糊查询 (5)综合查询 (6)统计功能 比如统计处某一类别的图书信息 或 筛选出小于指定数量库存的图书信息等等,总之,可以根据自己需求进行分析功能。 一、提交材料应包括:(1)系统源代码 (2)课程报告 二、整个设计过程具体要求 (1)需求分析 要求学生对案例系统进行分析,设计出需要完成的功能,完善任务 要求 各个模块的调用关系; (2)设计过程 要求学生进一步明确各模块调用关系,进一步完善模块函数细节(函数名、参数、返回值等) (3)实现过程 要求学生养成良好的编码习惯、完成各个模块并进行测试,最终完成系统整体测试; (4)总结阶段 按照要求完成系统设计和实现报告,并进行总结、答辩。 报告撰写情况(30分) 系统完成情况(30分) 答辩情况(40分) 内容 规范程度 程序测试 基本功能扩展功能自述情况答辩情况 20分 5分 5分 20分 10分 10分 30分 总分 成绩 评定
成绩评定教师:
一. 需求分析
本次C语言程序设计以“图书馆管理系统”为题,题目要求开发一个图书信息管理系统,图书信息包括:图书编号、书名、作者、出版社、类别、出版时间、价格等基本信息(也可以根据自己的当前能力进行扩充)。
基本功能包括:
(1)图书信息录入功能(图书信息用文件保存)--输入 (2)图书信息浏览功能--输出
(3)查询功能(至少一种查询方式)、排序功能(至少一种排序方式): ①按书名查询 ②按作者名查询 ③ 按照价钱排序 ④按出版时间排序等等
(4)图书信息的删除与修改
当然,也可以根据个人的情况进行适当的扩展:比如权限处理啊,报表打印功能,模糊查询,统计功能,或 筛选出小于指定数量库存的图书等等。
测试数据有ASCII文件tushu_list.txt提供: tushu_list.txt文件结构:(无序)
图书编号 书名 作者 出版社 类别 出版社时间 价格 -------------------------------------------------------------------- 1001 三国演义 罗贯中 民族文学出版社 小说 1585 55.5 1008 孟子 孟子 人民教育出版社 古籍 1981 23.33 1002 水浒传 施耐庵 民族文学出版社 小说 1582 48.36 1003 西游记 吴承恩 民族文学出版社 小说 1602 46.38 1006 线性代数 同济 同济大学出版社 教育 2010 19.98 1010 新视野 郑树棠 外研社 教育 2009 32.90 1007 春秋 孔子 人民教育出版社 古籍 1980 22.22 1009 时间简史 霍金 外研社 科普 1977 35.31 1004 红楼梦 曹雪芹 民族文学出版社 小说 1621 49.59 1005 高等数学 同济 同济大学出版 教育 2010 29.6
二概要设计
(1).数据结构
根据题目给定的图书信息和数据格式可知道,链表结点必须用结构体实现。故:首先建立结构体数组:
struct tushu{
};
char num[10]; 字符型图书编号 char name[20]; 字符型书名 char writer[20]; 字符型作者 char press[20]; 字符型出版社 char kind[20]; 字符型类别 double time; 双精度实型出版时间 double price; 实型价格
struct tushu *next; 用与构建连表指向下一结点
FILE *fp; 定义全局变量fp
(2).模块划分 定义全局变量:
FILE *fp; /* 定义全局变量fp*/ 函数原型清单: /*密码验证*/ void secret(); /*主菜单*/ void menu(); /*录入图书信息*/ struct tushu * Input(); /*将信息导入文件可追加*/
void fprint(struct tushu *head); /*将信息导入文件只写(可覆盖)*/ void fprint_(struct tushu *head); /*从tushu_list中读取数据构建链表*/
struct tushu * create(struct tushu * head,int *n); /*浏览全部图书信息*/
void Browse(struct tushu *head); /*统计图书数目*/
void count(struct tushu *head); /*按书名查询图书*/
void Findofname(struct tushu *head); /*按作者查询图书*/
void Findofwriter(struct tushu *head); /*按类别查询图书*/
void Findofkind(struct tushu *head); /*按出版时间排序*/
void Sort_time(struct tushu * head); /*按价格排序*/
void Sort_price(struct tushu * head); /*按图书编号排序*/
void Sort_num(struct tushu * head); /*按编号删除图书*/
struct tushu * Delete(struct tushu * head,char m[15]); /*修改图书*/
struct tushu * Revise(struct tushu *head); (3).程序总体框架
模块层次结构只确定了模块之间的关系以及函数原型,不是程序的执行步骤。程序的总体框架是程序的总体流程图。此程序并非是按照顺序逐一执行的,其中有某些程序他们之间的关系并不是递进,而是并列。所以选取一个合适的菜单是最佳方案。程序的总体框架如下:
由主函数进入程序 密码验证 未通过 通过后输出主菜单 图书馆图书管理系统 0-退出系统 6-按类别查询 1-添加新图书 7-按时间排序 2-浏览图书 8-按价格排序 3-统计图书数目 9-按编号排序 4-按书名查询 10-按编号删除图书 5-按作者查询 11-修改图书 输入对应编号 三.功能模块的详细设计
主菜单
1.函数原型,功能及形参说明 函数原型:void menu()
函数功能:实现系统的菜单调用,显示对应选项 参数说明:函数类型为空 2.程序清单
0-1-2-3-4-5-6-7-8-9-10-11-退出系统添加新图书浏览图书统计图书数目按书名查询按作者查询按类别查询按时间排序按价格排序按编号排序按编号删除图书修改图书
void menu() {
printf(\"\\n**************************************************\\n\"); } 密码验证
1.函数原型,功能及形参说明 函数原型:void secret()
函数功能:实现系统的密码验证功能
参数说明: char a[20] 20个字符以内的密码输入 system(\"cls\"); 库函数 清频 2.程序清单 void secret() {
char a[20];
printf(\"**进入图书管理系统前请先进行密码验证---\"); do{
gets(a); /*输入密码*/ system(\"cls\"); /*调用库函数清屏*/ printf(\"对不起!您输入的密码有误,请重新输入---\");
printf(\" 图书馆图书管理系统 \\n\"); printf(\"---------------------------------------------------\\n\"); printf(\" 0-退出系统 6-按类别查询 \\n\"); printf(\" 1-添加新图书 7-按时间排序 \\n\"); printf(\" 2-浏览图书 8-按价格排序 \\n\"); printf(\" 3-统计图书数目 9-按编号排序 \\n\"); printf(\" 4-按书名查询 10-按编号删除图书 \\n\"); printf(\" 5-按作者查询 11-修改图书 \\n\"); printf(\"---------------------------------------------------\\n\"); printf(\"__________________________________________________ \\n\");
}
}while(strcmp(a,\"0605\")!=0); /*单一密码“0605”*/ system(\"cls\");
printf(\" 欢迎进入图书管理系统\\n\");
添加新图书及是否保存 1.函数原型,功能及形参说明 函数原型:struct tushu * Input()
函数功能:实现图书的添加及保存(其中调用函数void fprint(struct tushu
*head);/*将信息导入文件可追加*/)
参数说明:*head 链表头结点指针 *p1,*p2 辅助结点 局外变量 2.程序清单
/*录入图书信息建立图书信息的链表*/ struct tushu * Input() {
struct tushu *p1,*p2,*head; /*建立辅助结点及头结点*/ char num; int n=0,x; system(\"cls\"); menu();
printf(\"\\n请按对应项输入图书信息以#结束:\\n\"); p1=(struct tushu *)malloc(sizeof(struct tushu)); head=p2=p1;
do{ /*使用do while语句输入图书信息*/
scanf(\"%s\
if(strcmp(p1->num,\"#\")==0)break; /*判断结束符*/ else
scanf(\"%s%s%s%s%lf%lf\
p1->name,p1->writer,p1->press,p1->kind,&p1->time,&p1->price);
}
num='#'; /*???*/ p1=(struct tushu *)malloc(sizeof(struct tushu)); p2->next=p1; p2=p1; n++;
}while(1); p1->next=NULL;
printf(\"图书信息输入结束!\\n\"); getchar();
printf(\"是否保存图书信息?(1.是/2.否):\"); scanf(\"%d\if(x==1)
fprint(head); /*调用函数保存至文件*/
else
printf(\"\\n文件没有被保存!\\n\");
return head; /*返回头指针*/
将信息导入文件可追加 1.函数原型,功能及形参说明
函数原型:void fprint(struct tushu *head) 函数功能:实现图书的保存将信息导入文件可追加 参数说明:struct tushu *head 链表头结点指针 2.程序清单
void fprint(struct tushu *head) {
struct tushu *p1;
if((fp=fopen(\"tushu_list.txt\{
printf(\"File open error!\\n\");
}
exit(0);
for(p1=head;p1->next!=NULL;p1=p1->next) /*遍历*/
fprintf(fp,\"%s\%s\%s\%s\%s\%.0lf\%lf\\n\
p1->num,p1->name,p1->writer,p1->press,p1->kind,p1->time,p1->price
);/*将图书信息写入文件*/ }
将信息导入文件不可追加 1.函数原型,功能及形参说明
函数原型:void fprint_(struct tushu *head)
函数功能:实现修改及删除后的图书保存将信息导入文件并覆盖原文件 参数说明:struct tushu *head 链表头结点指针 2.程序清单
void fprint_(struct tushu *head) {
struct tushu *p1;
if((fp=fopen(\"tushu_list.txt\{ }
for(p1=head;p1!=NULL;p1=p1->next) /*遍历*/
fprintf(fp,\"%s\%s\%s\%s\%s\%.0lf\%lf\\n\printf(\"File open error!\\n\"); exit(0);
fclose(fp); /*关闭文件*/ system(\"cls\"); menu();
printf(\"\\n图书信息已成功保存到文件 tushu_list.txt 中!\\n\"); getchar();
p1->num,p1->name,p1->writer,p1->press,p1->kind,p1->time,p1->price
);/*将图书信息写入文件*/ }
浏览图书信息
1.函数原型,功能及形参说明
函数原型:void Browse(struct tushu *head) 函数功能:实现图书信息的输出
参数说明:struct tushu *head 链表头结点指针 2.程序清单
void Browse(struct tushu *head) /*浏览全部图书信息*/ {
fclose(fp); /*关闭文件*/ system(\"cls\"); menu();
printf(\"\\n图书信息已成功保存到文件 tushu_list.txt 中!\\n\"); getchar();
char num[10]; char name[20]; char writer[20]; char press[20]; char kind[20]; double time; double price; system(\"cls\"); menu();
if((fp=fopen(\"tushu_list.txt\{ }
printf(\"File open error!\\n\"); exit(0);
printf(\"---------------------------------------------------\\n\"); printf(\"编号 书名 作者 出版社 类别 出版时间 价格\\n\"); while(!feof(fp))/*读取并输出*/ {
fscanf(fp,\"%s%s%s%s%s%lf%lf\
num,name,writer,press,kind,&time,&price);
printf(\" %s\%s\%s\%s\%s\%.0lf\%.2lf\\n\
num,name,writer,press,kind,time,price);
}
};
if(fclose(fp)) { }
printf(\"Can not close the file!\\n\"); exit(0);
从tushu_list中读取数据构建链表 1.函数原型,功能及形参说明
函数原型:struct tushu * create(struct tushu * head,int *n) 函数功能:建立图书信息单向链表
参数说明:struct tushu *head 链表头结点指针 int *n 图书数目指针 2.程序清单
struct tushu * create(struct tushu * head,int *n) {
struct tushu *p,*p1,*p2;
if((fp=fopen(\"tushu_list.txt\先安全打开目录文件*/ { }
printf(\"File open error!\\n\"); exit(0);
}
while(!feof(fp))/*读取并创建链表*/ { }
p2->next=NULL;
free(p); /*释放辅助结点所占用空间*/ (*n)--; fclose(fp); return head;
(*n)++;
p=(struct tushu *)malloc(sizeof(struct tushu)); fscanf(fp,\"%s%s%s%s%s%lf%lf\
p->num,p->name,p->writer,p->press,p->kind,&p->time,&p->price); if(head==NULL){ } else{ }
p1->next=p; p2=p1; p1=p; head=p; p1=p;
统计图书数目
1.函数原型,功能及形参说明
函数原型:void count(struct tushu *head) 函数功能:实现图书信息数目统计并输出
参数说明:struct tushu *head 链表头结点指针 n 计数 2.程序清单
void count(struct tushu *head) /*统计图书数目*/
{
int n=0;
struct tushu *p1;
head=create(head,&n); /*调用创建链表函数*/ for(p1=head;p1->next!=NULL;p1=p1->next) /*遍历*/
n++; /*计数*/
printf(\"\\n此系统统计在内的图书共有 %d 册。\\n\计算并输
出图书数目*/ }
按书名查询图书信息 1.函数原型,功能及形参说明
函数原型:void Findofname(struct tushu *head) 函数功能:实现图书信息按照书名查询并输出 参数说明:struct tushu *head 链表头结点指针 i 计数判定
char b[20]; 查找编号
2.函数流程图
Findofname head!=NULL遍历 i=0; strcmp(p->name,b) 输入目标图书名称10[b] =0 i!=0 p=p->next 未找到 输出图书信息 =0i++ !=0
3.程序清单
void Findofname(struct tushu *head) /*按书名查询图书*/
{
int i=0,n; /*i为计数判定*/ char b[20]; /*定义查找编号*/ struct tushu *p; head=create(head,&n); p=head; system(\"cls\"); menu();
printf(\"\\n请输入要查询的图书名称:\"); scanf(\"%s\while(p!=NULL){
if(strcmp(p->name,b)==0){ /*比较输入的字符串与原文件中书名*/
printf(\"\\n编号 书名 作者 出版社 类别 出版时间
价格\\n\"); }
按作者查询图书
1.函数原型,功能及形参说明
函数原型:void Findofwriter(struct tushu *head) 函数功能:实现图书信息按照图书作者查询并输出 参数说明:struct tushu *head 链表头结点指针 2.程序清单
} if(i==0)
printf(\"\\n对不起!没有找到名为《%s》的图书!\\n\
printf(\"%s\%s\%s\%s\%s\%.0lf\%.2lf \\n\
p->num,p->name,p->writer,p->press,p->kind,p->time,p->price); }
p=p->next;
i++;
void Findofwriter(struct tushu *head) {
int i=0,n; char b[20]; struct tushu *p; head=create(head,&n); p=head; system(\"cls\"); menu();
printf(\"\\n请输入要查询的图书作者姓名:\"); scanf(\"%s\while(p!=NULL){
if(strcmp(p->writer,b)==0){
printf(\"\\n编号 书名 作者 出版社 类别 出版时间
价格\\n\"); }
按类别查询图书
1.函数原型,功能及形参说明
函数原型:void Findofkind(struct tushu *head) 函数功能:实现图书信息按照图书类别查询并输出 参数说明:struct tushu *head 链表头结点指针
printf(\"%s\%s\%s\%s\%s\%.0lf\%.2lf \\n\
p->num,p->name,p->writer,p->press,p->kind,p->time,p->price); } if(i==0)
printf(\"\\n对不起!没有找到‘ %s ’所著的相关图书!\\n\ }
p=p->next;
i++;
2.程序清单
void Findofkind(struct tushu *head) {
int i=0,n; char b[20]; struct tushu *p; head=create(head,&n); p=head; system(\"cls\"); menu();
printf(\"\\n请输入您要查询的图书类别:\"); scanf(\"%s\while(p!=NULL){
if(strcmp(p->kind,b)==0){
printf(\"\\n编号 书名 作者 出版社 类别 出版时间
价格\\n\"); }
按出版时间排序
1.函数原型,功能及形参说明
函数原型:void Sort_time(struct tushu * head)
函数功能:实现图书信息按照出版时间并输出 ,但此过程并不被储存至文件
} if(i==0)
printf(\"\\n对不起!没有找到类别为‘ %s ’的图书!\\n\
printf(\"%s\%s\%s\%s\%s\%.0lf\%.2lf \\n\
p->num,p->name,p->writer,p->press,p->kind,p->time,p->price); }
p=p->next;
i++;
参数说明:struct tushu *head 链表头结点指针
struct tushu *p,*tail; 定义辅助变量用于选择排序 2.程序清单
void Sort_time(struct tushu * head) {
struct tushu *p,*tail; /*定义中间变量*/
double time;
int n;
p=(struct tushu *)malloc(sizeof(struct tushu));/*分配动态空间*/ system(\"cls\"); menu();
head=create(head,&n);
while(head->next!=NULL) /*利用选择法排序*/ {
tail=NULL;
p=head;
time=p->time; /*将链表中第一个时间赋给time*/ while(p!=NULL)
{
if((p->time)