C语言课程设计实验设备管理_第1页
C语言课程设计实验设备管理_第2页
C语言课程设计实验设备管理_第3页
C语言课程设计实验设备管理_第4页
C语言课程设计实验设备管理_第5页
已阅读5页,还剩23页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、C程序设计课程设计报告 (2015-2016 学年度 第一学期)题 目 :实验室设备管理系统学 生 姓 名 : 宋波 学 号 : 1508210120 班 级 : 15计科3班 指 导 老 师 : 邓明 日 期 : 2016年4月9日 淮南师范学院计算机学院2016年4月9日 目 录1 课程设计名称及内容21.1程序设计组成框图22 任务要求33 课程设计报告内容33.1 流程图显示33.2 程序实现思路64 程序演示95 总结 136 源代码 1427实验室设备管理系统1、课程设计名称及内容课程设计名称:实验室设备管理系统设计内容:编写一个简单的实验室设备管理程序,帮助管理实验室设备信息。要

2、求具有设备信息管理的功能。其中包括设备信息的录入、删除、查询和修改等功能。还应包括对实验室信息管理的功能。其中包括对实验室信息的录入、删除、修改和查询等功能。程序设计组成框图实验设备信息输入模块实验设备信息添加模块实验设备信息修改模块实验设备分内统计模块实验设备查询模块功能选择实验设备管理系统设计2、任务和要求运用面向对象的程序设计方法,要求选择动态数组类模板或链表类模板,任务中要运用I/O流对象对文件进行读写操作。本题程序应提供的基本管理功能有:1) 添加:即增加一条信息到设备信息中,或增加一条信息到实验室信息中;2) 显示:即在屏幕上显示所有设备或实验室信息;3) 存储:即将设备信息和实验

3、室信息分别保存在文件中;4) 装入:即将文件中的信息读入程序;5) 查询:可根据设备名称查找具体情况,若找到,显示在屏幕上; 6) 修改:可修改设备信息,或对实验室信息进行修改。3、 课程设计报告内容head=NULL输入设备信息linkIsEmpty()p-next=NULLhead=NULLnewnode =pnewnode -next=pnewnode =p输入新设备信息返回头指针headNYYN3.1 流程图显示将新的设备信息插入链表链表为空head=NULLheadnewnode =p1newnode -next=NULLp1-next=p-nextp-next=p1输入信息返回头指

4、针newnodeYN删除节点操作的算法流程图输入要删除的设备的编号id链表是否为空head=NULL判断要删除的是否为头结点head-id=nidhead=head-p p-next=(p-next)-nextp-next!=NULLp-id=nidreturn NULLpt2=headhead=head-nextfree(pt2)p=p-next;p-next=(p-next)-next; return true返回头指针headYNYNYNYN3.2 程序实现思路定义一个结点类,用于存放实验室设备的各种信息;定义一个Link类,把数据以链表的形式存储,链表的每个结点为一个Node对象;定义

5、一个Shebei类,用于包装Link类及菜单操作;定义Link类和Shebei类的成员函数,实现要求的各种功能;Link类:class Link/Link类,把数据以链表的形式存储,链表的每个结点为一个Node对象private: Node *head; /链表的头指针,为Node对象类型的指针public : Link();/构造函数,初始化变量 bool linkIsEmpty();/判断链表是否为空 void linkInsert(Node *newnode);/向链表中插入新的结点 bool linkDelete(int nid);/从链表中删除的结点 void linkClear()

6、;/清空链表中数据 void linkView();/查看链表中数据 Node* linkFind(int nid);/在链表中查找id为nid结点,返回指向该结点的指针 Node* getHead();/获取头指针;Shebei类:class Shebeiprivate: Link clink;/Link对象成员 bool k;/记录数据是否被修改public: Shebei(); void ShebeiClear(); void ShebeiInsert(); void ShebeiDelete(); void ShebeiFind();void ShebeiModify(); void

7、ShebeiView(); void ShebeiLoad(); void ShebeiSave(); void Exit();/退出程序 void showMenu();/显示菜单 void showTip();/显示操作提示 void doMenu(char n);/执行相应菜单项功能;然后就是各个函数的具体定义。菜单选择功能的实现,使用switch语句;菜单选择函数的定义:void Shebei:showMenu() couttt*endl; couttt* 实验室设备管理系统 *endl;couttt* *endl;couttt* 1-清空:清除所有设备信息 *endl;couttt*

8、 *endl;couttt* 2-添加:增加一个设备到设备信息中 *endl;couttt* *endl;couttt* 3-删除:删除指定设备数据 *endl; couttt* *endl;couttt* 4-查找:根据设备数据查找设备信息 *endl;couttt* *endl;couttt* 5-修改:修改指定设备信息 *endl;couttt* *endl;couttt* 6-显示:在屏幕上显示所有设备的信息 *endl;couttt* *endl;couttt* 7-存储:将设备信息保存在一个文件中 *endl;couttt* *endl;couttt* 0-退出:安全的退出本系统

9、*endl; couttt*endl;void Shebei:showTip() coutendl; cout*操作完成*endl; cout*选择07 继续*endl; cout请选择:;void Shebei:doMenu(char n) switch(n) case 1: ShebeiClear(); break; case 2: ShebeiInsert(); break;case 3: ShebeiDelete();break; case 4: ShebeiFind(); break;case 5: ShebeiModify(); break; case 6: ShebeiView(

10、); break; case 7: ShebeiSave(); break; case 0: Exit(); break; default: cout输入错误!; 4、 程序演示4.1、进入系统4.2添加设备信息 4.3删除指定设备信息 4.4根据设备数据查找设备信息 4.5 修改设备信息4.6 显示所有设备信息4.7 将设备信息存储在文本中5、 总结经过一个星期的C语言程序设计,让我明白到了C语言这门课的重要性,C语言作为一门电脑学的基础课,是我们必须掌握的顺电脑飞速发展的今天,掌握电脑的应用是如今每一位大学生所必须掌握的,掌握电脑有对各人来说有我种好处,学习电脑是一种本领,也是一种生存的技

11、能,而C语言做为程序的基础,掌握它更是我们这些大学生所必须掌握的。经过这次程序设计,让我认识到了C语言的运用是相当广泛的,才拿到题目的时候,我真的不知道该怎么办,但随着慢慢的设计,思路也总算有了,这样才能继续进行下去,这时我才真正认识到了C语言的功能原来是那么的多。一个复杂的实验室设备管理系统,经过500-600行的代码就可以完完全全的达到,这是让我非常惊讶的,但相对,如今的C语言也是非常难的,这学期学到的一些内容,都是C语言的重点,但学下来以后感觉还是很难所以必须先打好基础,基础好了,学什么都会容易很多。这次的程序设计让我重新认识到了C语言,这是一门非常重要的科目,我们必须付出很多倍的努力学

12、习它,才能熟练地掌握它。源代码#include#include#include#include#includeusing namespace std;class Node /结点类,用于存放客户的各种信息public: long id; /实验设备编号 string name; /名称 string type; /设备类型string suoshushiyanshi; /实验设备所属实验室string buytime; /购买时间string price; /价格string amount; /库存量string shengchanriqi; /生产日期string shiyongshoumi

13、ng; /使用寿命 string weight; /重量 Node *next; /指向下一结点的指针 Node(long id=000,string nname=noname,string ntype=unkown,string nsuoshushiyanshi=unknow,string nbuytime=unknow,string nprice=unknow,string namount=unknow, string nshengchanriqi=unkown,string nshiyongshouming=unknow,string nweight=unknow );/构造函数,初始化

14、变量;class Link/Link类,把数据以链表的形式存储,链表的每个结点为一个Node对象private: Node *head; /链表的头指针,为Node对象类型的指针public : Link();/构造函数,初始化变量 bool linkIsEmpty();/判断链表是否为空 void linkInsert(Node *newnode);/向链表中插入新的结点 bool linkDelete(int nid);/从链表中删除的结点 void linkClear();/清空链表中数据 void linkView();/查看链表中数据 Node* linkFind(int nid);

15、/在链表中查找id为nid结点,返回指向该结点的指针 Node* getHead();/获取头指针;Node:Node(long nid, string nname, string ntype,string nsuoshushiyanshi,string nbuytime,string nprice,string namount, string nshengchanriqi,string nshiyongshouming,string nweight) id=nid; name=nname;type=ntype;suoshushiyanshi=nsuoshushiyanshi;buytime=

16、nbuytime;price=nprice;amount=namount;shengchanriqi=nshengchanriqi;shiyongshouming=nshiyongshouming; weight=nweight; next=NULL;Link:Link() /构造函数,初始化链表为空 head=NULL;bool Link:linkIsEmpty() /判断链表是否为空,空则返回true return(head=NULL); -共同设计void Link:linkInsert(Node *newnode) /按id值从小到大的顺序,插入新的结点 Node *p1; if(!h

17、ead)/链表为空的情况 head=newnode; else if(head-id)(newnode-id) /插入到第一个结点的情况 newnode-next=head; head=newnode; else /插入到第二个及以后情况 p1=head; while(1) if(!(p1-next) p1-next=newnode; break; else if(p1-next)-idnewnode-id) newnode-next=p1-next; p1-next=newnode; break; p1=p1-next; bool Link:linkDelete(int nid) /删除结点

18、,成功则返回true Node *p; if(head=NULL)/链表为空的情况 return false; if(head-id=nid) /删除的为第一个结点的情况 head=head-next; return true; p=head; while(p-next) /删除的为第二个及以后结点的情况 if(p-next)-id=nid) p-next=(p-next)-next; return true; p=p-next; return false; -由陈广鹏设计void Link:linkClear() /清空链表 head=NULL;Node* Link:linkFind(int

19、 nid) /查找id值为nid的结点,返回该结点的指针 Node *p=head; /没找到符合条件的结点的话,返回的指针值为NULL while(p) if(p-id=nid) break; else p=p-next; return p;void Link:linkView() /显示链表数据 Node *p=head; while(p) cout实验设备编号:idendl; cout名称:nameendl; cout类型:typeendl; cout所属实验室:suoshushiyanshiendl; cout购买时间:buytimeendl; cout价格:priceendl; co

20、ut库存量:amountendl; cout生产日期:shengchanriqiendl; cout使用寿命:shiyongshoumingendl; cout重量:weightendl; cout*next; Node* Link:getHead() return head;/类Shebei,用于包装Link类及菜单操作class Shebeiprivate: Link clink;/Link对象成员 bool k;/记录数据是否被修改public: Shebei(); void ShebeiClear(); void ShebeiInsert(); void ShebeiDelete();

21、 void ShebeiFind();void ShebeiModify(); void ShebeiView(); void ShebeiLoad(); void ShebeiSave(); void Exit();/退出程序 void showMenu();/显示菜单 void showTip();/显示操作提示 void doMenu(char n);/执行相应菜单项功能;Shebei:Shebei() Link();/调用成员对象的构造函数 ShebeiLoad();/从文件中读取数据,创建链表 k=false;/设置数据被修改 void Shebei:ShebeiClear() /清

22、空设备记录 clink.linkClear(); cout成功清空设备信息记录!endl;void Shebei:ShebeiInsert() /插入设备记录 Node *p=new Node(); coutp-id; coutp-name; coutp-type;coutp-suoshushiyanshi;coutp-buytime; coutp-price; coutp-amount; coutp-shengchanriqi;coutp-weight; if(!clink.linkFind(p-id) /判断设备信息是否存在 clink.linkInsert(p); k=true; els

23、e cout设备编号为id的的设备已存在,插入失败!endl; -由陈磊设计void Shebei:ShebeiDelete() /删除设备记录 long i; if(clink.linkIsEmpty()/链表为空的情况 cout没有设备记录!endl; else couti; if(clink.linkDelete(i) cout成功删除编号为i的实验记录!endl; k=true; else cout没有找到编号为i的设备!endl; void Shebei:ShebeiFind() /查找某编号的设备记录 long n; Node *p; if(clink.linkIsEmpty()/

24、链表为空的情况 cout没有设备记录!endl; else coutn; p=clink.linkFind(n);/获得找到的结点的指针 if(p) /指针值不为NULL时 cout实验设备编号:idendl; cout名称:nameendl; cout类型:typeendl; cout所属实验室:suoshushiyanshiendl; cout购买时间:buytimeendl; cout价格:priceendl; cout库存量:amountendl; cout生产日期:shengchanriqiendl; cout使用寿命:shiyongshoumingendl; cout重量:weig

25、htendl; else/指针值为NULL时 cout没有找到编号为n的设备记录!endl; void Shebei:ShebeiModify() /修改某编号的设备信息 long n; Node *p; if(clink.linkIsEmpty()/链表为空的情况 cout没有设备记录!endl; else coutn; p=clink.linkFind(n);/获得找到的结点的指针 if(p) /指针值不为NULL时 cout实验设备编号:idendl; cout名称:nameendl; cout类型:typeendl; cout所属实验室:suoshushiyanshiendl; cou

26、t购买时间:buytimeendl; cout价格:priceendl; cout库存量:amountendl; cout生产日期:shengchanriqiendl; cout使用寿命:shiyongshoumingendl; cout重量:weightendl;cout请输入新的设备信息endl;coutp-id; coutp-name; coutp-type; coutp-suoshushiyanshi; coutp-buytime; coutp-price; coutp-amount; coutp-shengchanriqi; coutp-weight; else/指针值为NULL时

27、cout没有找到编号为n的设备记录!endl; -由边飞设计void Shebei:ShebeiView() /显示所有设备的记录 if(clink.linkIsEmpty() cout没有设备记录!endl; else clink.linkView();void Shebei:ShebeiLoad() /从文件中读入数据,创建链表 Node *p; long nid; ifstream infile(data.txt); if(!infile) cerrnid) /读取客户,直到读空 p=new Node(); p-id=nid; infilep-name ; /读取名称 infilep-t

28、ype ;infilep-suoshushiyanshi ; infilep-buytime ; infilep-price ; infilep-amount ; infilep-shengchanriqi ;infilep-weight ; clink.linkInsert(p); infile.close(); /关闭文件void Shebei:ShebeiSave() /将数据保存到文件 Node *p=clink.getHead(); ofstream outfile(data.txt); if(!outfile) cerr错误:数据文件不能打开!n; else while(p) outfileid name type suoshushiyanshi buytime price amount shengchanriqi weight next; k=false; cout保存成功!endl; void Shebei:Exit() char s=Y; if(k) /判断数据是否修改 couts; if(s=y|s=Y) ShebeiSave(); cout已安全退出,; system

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论