《C语言程序设计课程设计报告图书信息管理系统.doc》由会员分享,可在线阅读,更多相关《C语言程序设计课程设计报告图书信息管理系统.doc(36页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、东莞理工学院C语言程序设计课程设计题 目:图书信息管理系统院 系:会计学院专 业:会计学年 级:2012班 别: 4班 指导教师:组 长: 同组成员:目录一、目1二、需求分析1三、概要设计1四、详细设计3五、调试分析4六、测试结果5七、用户使用说明12八、课程设计总结.12附录:参考代码13图书信息管理系统13一 目 本课程设计为学生提供了一个既动手又动脑,自学,查资料,独立实践机会。将本学期课本上理论知识和实际有机结合起来,锻炼学生实际分析问题和解决问题能力,提高学生适应实际、实践编程能力,使对C语言系统编程有一个大致了解。 二 需求分析 根据图书馆图书信息管理需要,建立一个“图书信息管理系
2、统”,以方便对图书各项管理操作。开发目如下:1、图书信息包括:登录号、书名、作者名、分类号、出版单位、出版时间、价格等。2、图书信息管理系统,提供以下功能: 1)图书信息录入功能(图书信息用文件保存)输入;2)图书信息浏览功能输出 ;3)查询和排序功能:算法 ;4)按书名查询 ;5)按作者名查询 ;6) 按登录号从大到小排列;7)图书信息删除及修改 三 概要设计 程序总体功能框架: 开 始 界 面 主 要 提 示 的 菜 单 界 面 删 除 图 书 信 息 浏 览 图 书 信 息 查 询 图 书 信 息 修 改 图 书 信 息 插 入 图 书 信 息采用结构: struct tsxx/定义结构
3、long dlnum;/定义登录号char bname10;/定义书名char aname10;/定义作者名char scnum10;/定义分类号char plname10;/定义出版社名char time11;/定义录入时间float price;/定义价格struct tsxx * next;/定义指向下一个结构首地址;链表结构:struct tsxx Bstruct tsxx Aheadstruct tsxx DNULLstruct tsxx C各功能独立自定义函数:1、插入图书信息(按登录号从大到小排序):struct tsxx * zengjia(struct tsxx * head
4、)/传递链表首地址,并返回链表首地址2. 、浏览全部图书信息:void Ptrint_Stu_Doc(struct tsxx *head)/传递链表首地址3、查询图书信息(包括书名查询和作者名查询):void Check(struct tsxx * head)/传递链表首地址4、删除图书信息:struct tsxx * Delete(struct tsxx * head)/传递链表首地址,并返回链表首地址5.、修改图书信息:struct tsxx * revise(struct tsxx * head)/传递链表首地址,并返回链表首地址其他一些变量定义:long size;/定义结构大小FIL
5、E * fp;/定义文件指针,指向文件struct tsxx * head;/定义链表首地址struct tsxx * p;/定义结构指针char choice;/定义选择变量四 详细设计 1、 设计思路: 首先,输入一些图书信息,申请一个结构类型动态内存,把图书信息赋值到动态内存内,每一快动态内存存放一本图书信息,并形成一条链表,比较登录号大小,按登录号从大到小排列;然后,建立并打开一个文件,把链表中数据写入文件中,然后关闭文件;最后,插入功能:先把所有数据从文件中读出来,申请动态内存来存放,形成链表,输入你想要插入图书信息,比较登录号大小,然后把新图书信息按照登录号大小顺序插入链表里面,新
6、建一个文间,把新链表写入文件中;浏览功能:先把所有数据从文件中读出来,申请动态内存来存放,形成链表,然后链表头开始,把结构中数据一个一个输出到界面上;查询功能:先把所有数据从文件中读出来,申请动态内存来存放,形成链表;选择你要查询方式:1是按书名查询,2是按作者名查询。输入你选择,判断你查询方式。书名查询:输入你要查询书名,在链表中查找你这本书,然后把这本书信息输出到界面上;作者名查询:输入你要查询作者名,在链表中查找对应作者名图书信息,并把信息输入到界面上;修改功能:先把所有数据从文件中读出来,申请动态内存来存放,形成链表,输入你要修改图书登录号,在链表中查找对应登录号图书信息结构,重新输入
7、你要修改图书全部信息,并把这些新图书信息赋值给找到结构,覆盖旧图书信息,新建一个文件,存放新图书信息;删除功能:先把所有数据从文件中读出来,申请动态内存来存放,形成链表,输入你要删除图书登录号,在链表中查找对应登录号图书信息结构及前一个结构,让前一个结构next指向对应登录号结构下一个结构,释放动态内存,新建一个新文件,存放新图示信息;2、 数据结构选择:据图书信息表特点,决定选用链表这种数据结构(也可用其它数据结构)来作为组成成绩数据库基本框架。链表是最简单也是最常用一种动态数据结构。它是对动态获得内存进行组织一种结构。选用链表有得好处:1. 即用即申请,不会造成内存空间浪费;2. 是数据之
8、间既有独立性,又便于数据相互连系;3. 便于数据添加及删除等优点。3、设计思想选择: 用模块化程序设计理念,对各个功能定义不同函数,分块处理,这样有利于后期调试及今后对功能完善。五 调试分析 1、 把数据从文件中拿出来时,当文件是空,它也会读数据,这时数据时0;当文件不空时,最后数据会被读两次。因此,这样读出来文件就会出现一些小差错,必须做适当调整。当文件为空,把链表首地址head赋值为NULL,然后释放动态内存;当文件不为空时,把链表最后第二个结构next赋值为NULL,然后释放动态内存。2、 因为开始时定义choice为整型变量,所以只能输入整数,如果不小心输入字符数时,整个程序就出现错误
9、,不能继续运行。因此,我们把choice重新定义成字符型,这样就可以输入字符数,所以后面用switch时,也要改成字符型。3、 一开始运行程序是,因为还没有创建文件,所以在读取文件中数据时,就会出现“不能打开文件”错误。因此,在一开始运行程序时必须要先创建一个文件,以后程序就会自动建立一个新文件。4、 在作者名查询那里,一开始是当查找到一条对应结构数据时,因为用了break,所以就直接退出了循环,因此如果一个作者有多本书是,以只能查询一本书信息。调试后,我们把break删掉,这样它就会一直循环,直到链表最后一条数据,它才会跳出循环。这样就能把一个作者全部书都显示出来。六 测试结果1、 数据输入
10、:新建一个文件,并把数据写入文件中:增加功能:查询功能:浏览功能:修改功能:删除功能:七 用户使用说明一开始运行程序时,就会出现一个让你选择界面,1.是增加数据,2是查询数据,3是浏览数据,4是修改数据,5是删除数据,6是输入数据,并新建一个文本存这些数据,0是退出程序。当你输入1时,界面就会输出“Enter the static(lognum bookname authorname scorenum publishname time price):”,接着你就输入你要增加图书信息就可以了。当你输入2时,就会在出现一个让你选择界面,1是书名查询,2是作者名查询。当你输入1时,如果文件时空,界面
11、就会输出“N0 Records”,如果文件不是空,界面就会输出“Input bname:”,就着你就输入你要查询图书书名,如果文件中没有你要查询这本书,界面就会输出“There isnt this static!”,当文件中有你要查询这本书时,界面就会输出这本书全部信息。当你输入2时,如果文件时空,界面就会输出“N0 Records”,如果文件不是空,界面就会输出“Input aname:”,就着你就输入你要查询图书作者名,如果文件中没有你要查询这本书,界面就会输出“There isnt this static!”,当文件中有你要查询这本书时,界面就会输出这本书全部信息。当你输入3时,界面就会
12、输出全部图书全部信息;当你输入4时,界面就会输出“Input the lognum:”,接着你要输入你要修改图书登录号,如果文件时空,界面就会输出“Not records!”,如果文件不是空,但没有你所输入登录号图书,界面就会输出“There isnt this static!”,如果文件不是空,并且有你输入登录号图书,界面就会输出这本书全部信息,很“Retype the static:”,接着你重新输入这本书全部信息就可以了。当你输入4时,界面就会输出“Input dlnum:”,接着你就输入你要删除图书登录号就可以了。当你输入6时,界面就会输出“Enter the static(lognu
13、m bookname authorname scorenum publishname time price):”,接着你就输入你要增加图书信息就可以了。当你输入0时,就退出程序当你输入是其他数字或是字符时,界面就会输出“Enter error!”。八 课程设计总结做为这个小组组长,我觉得我们所设计程序今本上已经能够实现题目要求,并且运用链表,还用文件来存数据。但是,我觉得我们程序还是存在着一些不足之处。首先建立一个文件是文件名和拓展名都已经被规定好,其次是当文件为空时,程序运行时,当你输入得选择不是6是,会发生错误,所以一开始要先运行选择6,后才能运行其他选择,最后是运行查询、修改、删除功能,
14、你输入信息要跟文件中一致,才能实现,如果稍有不同,就不够实现这些功能了。另外,我想感谢我组员,因为我们是分工合作,他们有负责一个功能,有负责两个功能,而我主要是些主函数,在他们积极配合下,我们很快就把总程序写好,并调试完毕。所以我想感谢他们配合。因为集体力量是强大,只有我们积极合作,才能够准时完成这个课程设计。最后,我觉得在这个课程设计过程中,我学到了很多东西。第一是耐心,当你在调试程序中,看到了你设计程序出现了那么多错误,或者当显示0错误0警告,却不能运行,或者是运行结果不是你所期望时,我觉得这时候最是考验耐心时候,也只有耐心和永不言败信念,才能支持你逆流而上,解决所有困难。在这个过程中,我
15、试过用了几个钟时间找一个错误,而结果只是打错了一个定义。第二是沟通,因为我对C语言也比较熟了,有一些同学比较陌生,所以他们来问我,在我解答他们问题是,我深刻体会了沟通重要性,因为只有你沟通好,他们容易理解,你也不用浪费口舌去讲一些不必要知识点程序参考代码:/*.主函数.*/#include#include#includestruct bookinf /定义结构int num; char bname20; char wname10; char clanum14; char pubcom10; char pubtime10; float price; struct bookinf *next;lo
16、ng size;FILE * fp;struct bookinf * vitil(void)/从文件中拿出数据struct bookinf * p1,* p2,* p3;int num; char bname20; char wname10; char clanum14; char pubcom10; char pubtime10; float price; long i=0;if(fp=fopen(程序设计.txt,r)=NULL)/打开文件printf(can not open file 程序设计.txt!n);exit(0);while(! feof(fp)if(feof(fp) bre
17、ak;if(i=1)p3=p1;if(p1=(struct bookinf *)calloc(1,size)=NULL)printf(Not able to allocate memory.n);exit(1);fscanf(fp,%ld%s%s%s%s%s%f,&num,bname,wname,clanum,pubcom,pubtime,&price);p1-num=num;strcpy(p1-bname,bname);strcpy(p1-wname,wname);strcpy(p1-clanum,clanum);strcpy(p1-pubcom,pubcom);strcpy(p1-pubt
18、ime,pubtime);p1-price=price;if(i=0)p2=p1;elsep3-next=p1;i+; if(p2-next=p1)p2-next=NULL;elsep3-next=NULL;free(p1);fclose(fp);/关闭文件return p2;void inputchoice(void)printf(n Choice:n);printf(1.Addn);printf(2.Checkn);printf(3.Scann);printf(4.Revisen);printf(5.Delectn);printf(6.Enter the stacticn);printf(
19、0.Exitn);void write_to_txt(struct bookinf * head)/写入文件struct bookinf * p;if(fp=fopen(程序设计.txt,w)=NULL)printf(can not open file 程序设计.txt!n);exit(0);for(p=head;p;p=p-next)fprintf(fp,%ld %s %s %s %s %s %fn,p-num,p-bname,p-wname,p-clanum,p-pubcom,p-pubtime,p-price);fclose(fp);/*.增加功能.*/struct bookinf *
20、Enter(struct bookinf * head)/增加数据struct bookinf * p1,* p2,*p3;int num;char bname20; char wname10; char clanum14; char pubcom10; char pubtime10; float price; if(p1=(struct bookinf *)calloc(1,size)=NULL)printf(Not able to allocate memory.n);exit(1);printf(Enter the static(lognum bookname authorname sc
21、orenum publishname time price):n);scanf(%ld%s%s%s%s%s%f,&num,bname,wname,clanum,pubcom,pubtime,&price);p1-num=num;strcpy(p1-bname,bname);strcpy(p1-wname,wname);strcpy(p1-clanum,clanum);strcpy(p1-pubcom,pubcom);strcpy(p1-pubtime,pubtime);p1-price=price;p2=head;if(head=NULL)head=p1;head-next=NULL;else
22、while(p1-nump2-num)&(p2-next!=NULL)p3=p2;p2=p2-next;if(p1-numnum)if(head=p2)head=p1;elsep3-next=p1;p1-next=p2;elsep2-next=p1;p1-next=NULL;return head;/*.查询功能.*/void Check(struct bookinf * head) /查询,书名,作者名struct bookinf * ptr;char a;char bname10;char wname10;printf(n Choice:n);printf(1:bnamen2:anamen
23、);scanf(%s,&a);if(head=NULL)printf(nN0 Recordsn);else/链表非空 switch(a)case 1:/按书名查询printf(Input bname:);scanf(%s,bname);for(ptr=head;ptr;ptr=ptr-next)if(strcmp(ptr-bname,bname)=0 )printf( dlnum bname aname scnum plname time pricen);printf(%5ld %10s %10s %10s %10s %10s %8fn,ptr-num,ptr-bname,ptr-wname,
24、ptr-clanum,ptr-pubcom,ptr-pubtime,ptr-price);if(ptr=NULL)printf(There isnt this static!n);break;case 2:/按作者名查询printf(Input wname:);scanf(%s,wname);for(ptr=head;ptr;ptr=ptr-next)if(strcmp(ptr-wname,wname)=0)printf( num bname wname clanum pubcom pubtime pricen);printf(%3ld %3s %3s %3s %3s %3s %3fn,ptr
25、-num,ptr-bname,ptr-wname,ptr-clanum,ptr-pubcom,ptr-pubtime,ptr-price);if(ptr=NULL)printf(There isnt this static!n);break;default:printf(Enter error!n);break;/*.浏览功能.*/void Ptrint_Stu_Doc(struct bookinf *head)/浏览struct bookinf * ptr;if(head=NULL)printf(nNo Recordsn);else printf(nThe Books Information
26、 Are: n); printf( dlnum bname aname scnum plname time price n); ptr=head;while(ptr!=NULL)printf( %ld %s %s %s %s %s %6.3f n,ptr-num,ptr-bname,ptr-wname,ptr-clanum,ptr-pubcom,ptr-pubtime,ptr-price);ptr=ptr-next;/*.修改功能.*/struct bookinf * Revise(struct bookinf * head) /定义子函数struct bookinf * p1;int num
27、; char bname20; char wname10; char clanum14; char pubcom10; char pubtime10; float price; printf(Input the lognumn); /输出scanf(%ld,&num); /读取 长整形输出if(head=NULL) /开头空printf(Not records!n); /输出没结果 换行elsefor(p1=head;p1;p1=p1-next)if(p1-num=num) printf(%ld %s %s %s %s %s %fn,p1-num,p1-bname,p1-wname,p1-cl
28、anum,p1-pubcom,p1-pubtime,p1-price); /字节 大小printf(Retype the static:n); /输出scanf(%ld%s%s%s%s%s%f,&num,bname,wname,clanum,pubcom,pubtime,&price); /读取p1-num=num;strcpy(p1-bname,bname); /读取strcpy(p1-wname,wname);strcpy(p1-clanum,clanum);strcpy(p1-pubcom,pubcom);strcpy(p1-pubtime,pubtime);p1-price=price
29、;break; /退出循环if(p1=NULL)/ p1空printf(There isnt this static!n);return head;/*.删除功能.*/struct bookinf * Delete(struct bookinf * head) /删除struct bookinf * ptr1,* ptr2; /定义 指针1 2int num;printf(Input num:n);scanf(%ld,&num);if(head=NULL) /链表空return NULL;elsewhile(head!=NULL & head-num=num) /要被删除结点为表头结点 ptr
30、2=head;head=head-next;printf( num bname wname clanum pubcom pubtime pricen);printf(%5ld %10s %10s %10s %10s %10s %8fn,ptr2-num,ptr2-bname,ptr2-wname, /字节ptr2-clanum,ptr2-pubcom,ptr2-pubtime,ptr2-price);free(ptr2); /释放/要被删除结点为非表头结点ptr1=head;ptr2=head-next;while(ptr2!=NULL) /指针2非空if(ptr2-num=num)/ptr2
31、所指结点符合删除要求ptr1-next=ptr2-next;printf( num bname wname clanum pubcom pubtime pricen);printf(%5ld %10s %10s %10s %10s %10s %8fn,ptr2-num,ptr2-bname,ptr2-wname,ptr2-clanum,ptr2-pubcom,ptr2-pubtime,ptr2-price);free(ptr2);elseptr1=ptr2;/ptr1后移一个节点ptr2=ptr1-next;/ptr2指向ptr1后一个节点return head;main()struct bo
32、okinf * head=NULL,* p;char choice;size=sizeof(struct bookinf);inputchoice();scanf(%s,&choice);while(choice!=0)switch(choice)case 1:head=vitil();/把数据从文件中取出来head=Enter(head);/增加数据write_to_txt(head);/写入文件break;case 2:head=vitil();/把数据从文件中取出来 Check(head);/查询 break;case 3:head=vitil();/把数据从文件中取出来 Ptrint_
33、Stu_Doc(head);/浏览 break;case 4:head=vitil();/把数据从文件中取出来head=Revise(head);/修改write_to_txt(head);break;case 5:head=vitil();/把数据从文件中取出来head=Delete(head);/删除write_to_txt(head);break;case 6:head=Enter(head); write_to_txt(head); break;default:printf(Enter error!n);break;inputchoice();scanf(%s,&choice);while(head!=NULL)/释放链表p=head;head=head-next;free(p);