ImageVerifierCode 换一换
格式:DOC , 页数:28 ,大小:464.33KB ,
资源ID:852135      下载积分:20 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 微信支付   
验证码:   换一换

加入VIP,免费下载资源
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.wodocx.com/d-852135.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(C++课程设计--实验室设备管理系统.doc)为本站会员(精***)主动上传,沃文网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知沃文网(发送邮件至2622162128@qq.com或直接QQ联系客服),我们立即给予删除!

C++课程设计--实验室设备管理系统.doc

1、目 录1 课程设计的目的22 课程设计名称及内容23 任务要求24 课程设计报告内容34.1流程图显示34.2程序实现思路65 程序演示96 总结14参考文献 14附录(源代码) 1527实验室设备管理系统1、课程设计目的将理论教学中涉及到的知识点贯穿起来,对不同的数据类型、程序控制结构、数据结构作一比较和总结,结合设计题目进行综合性应用,对所学知识达到融会贯通的程度。通过课程设计,学生在下述各方面的能力应该得到锻炼:(1)进一步巩固、加深学生所学专业课程C+程序设计语言的基本理论知识,理论联系实际,进一步培养学生综合分析问题,解决问题的能力。 (2)全面考核学生所掌握的基本理论知识及其实际业

2、务能力,从而达到提高学生素质的最终目的。 (3)利用所学知识,开发小型应用系统,掌握运用C+语言编写调试应用系统程序,训练独立开发应用系统,进行数据处理的综合能力。(4)对于给定的设计题目,如何进行分析,理清思路,并给出相应的数学模型。 (5)掌握结构化程序设计方法,熟悉面向对象程序设计方法。(6)熟练掌握C+语言的基本语法,灵活运用各种数据类型。(7)进一步掌握在集成环境下如何调试程序和修改程序。2、课程设计名称及内容课程设计名称:实验室设备管理系统设计内容:编写一个简单的实验室设备管理程序,帮助管理实验室设备信息。要求具有设备信息管理的功能。其中包括设备信息的录入、删除、查询和修改等功能。

3、还应包括对实验室信息管理的功能。其中包括对实验室信息的录入、删除、修改和查询等功能。3、任务和要求运用面向对象的程序设计方法,要求选择动态数组类模板或链表类模板,任务中要运用I/O流对象对文件进行读写操作。本题程序应提供的基本管理功能有:1) 添加:即增加一条信息到设备信息中,或增加一条信息到实验室信息中;2) 显示:即在屏幕上显示所有设备或实验室信息;3) 存储:即将设备信息和实验室信息分别保存在文件中;4) 装入:即将文件中的信息读入程序;5) 查询:可根据设备名称查找具体情况,若找到,显示在屏幕上; 6) 修改:可修改设备信息,或对实验室信息进行修改。4、 课程设计报告内容head=NU

4、LL输入设备信息linkIsEmpty()p-next=NULLhead=NULLnewnode =pnewnode -next=pnewnode =p输入新设备信息返回头指针headNYYN4.1 流程图显示将新的设备信息插入链表链表为空head=NULLheadnewnode =p1newnode -next=NULLp1-next=p-nextp-next=p1输入信息返回头指针newnodeYN删除节点操作的算法流程图输入要删除的设备的编号id链表是否为空head=NULL判断要删除的是否为头结点head-id=nidhead=head-p p-next=(p-next)-nextp-

5、next!=NULLp-id=nidreturn NULLpt2=headhead=head-nextfree(pt2)p=p-next;p-next=(p-next)-next; return true返回头指针headYNYNYNYN4.2 程序实现思路定义一个结点类,用于存放实验室设备的各种信息;定义一个Link类,把数据以链表的形式存储,链表的每个结点为一个Node对象;定义一个Shebei类,用于包装Link类及菜单操作;定义Link类和Shebei类的成员函数,实现要求的各种功能;Link类:class Link/Link类,把数据以链表的形式存储,链表的每个结点为一个Node对象

6、private: Node *head; /链表的头指针,为Node对象类型的指针public : Link();/构造函数,初始化变量 bool linkIsEmpty();/判断链表是否为空 void linkInsert(Node *newnode);/向链表中插入新的结点 bool linkDelete(int nid);/从链表中删除的结点 void linkClear();/清空链表中数据 void linkView();/查看链表中数据 Node* linkFind(int nid);/在链表中查找id为nid结点,返回指向该结点的指针 Node* getHead();/获取头指

7、针;Shebei类:class Shebeiprivate: Link clink;/Link对象成员 bool k;/记录数据是否被修改public: Shebei(); void ShebeiClear(); void ShebeiInsert(); void ShebeiDelete(); void ShebeiFind();void ShebeiModify(); void ShebeiView(); void ShebeiLoad(); void ShebeiSave(); void Exit();/退出程序 void showMenu();/显示菜单 void showTip();

8、/显示操作提示 void doMenu(char n);/执行相应菜单项功能;然后就是各个函数的具体定义。菜单选择功能的实现,使用switch语句;菜单选择函数的定义:void Shebei:showMenu() couttt*endl; couttt* 实验室设备管理系统 *endl;couttt* *endl;couttt* 1-清空:清除所有设备信息 *endl;couttt* *endl;couttt* 2-添加:增加一个设备到设备信息中 *endl;couttt* *endl;couttt* 3-删除:删除指定设备数据 *endl; couttt* *endl;couttt* 4-查

9、找:根据设备数据查找设备信息 *endl;couttt* *endl;couttt* 5-修改:修改指定设备信息 *endl;couttt* *endl;couttt* 6-显示:在屏幕上显示所有设备的信息 *endl;couttt* *endl;couttt* 7-存储:将设备信息保存在一个文件中 *endl;couttt* *endl;couttt* 0-退出:安全的退出本系统 *endl; couttt*endl;void Shebei:showTip() coutendl; cout*操作完成*endl; cout*选择07 继续*endl; cout请选择:;void Shebei:

10、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(); break; case 7: ShebeiSave(); break; case 0: Exit(); break; default: cout输入错误!; 5、 程序演示5.1、进入系统5.2添加设备信息

11、5.3删除指定设备信息 5.4根据设备数据查找设备信息 5.5 修改设备信息 5.6 显示所有设备信息5.7 将设备信息存储在文本中6、 总结经过一个星期的C+程序设计,让我明白到了C+这门课的重要性,C+作为一门电脑学的基础课,是我们必须掌握的顺电脑飞速发展的今天,掌握电脑的应用是如今每一位大学生所必须掌握的,掌握电脑有对各人来说有我种好处,学习电脑是一种本领,也是一种生存的技能,而C+做为电脑的基础,掌握它更是我们这些大学生所必须掌握的。经过这次程序设计,让我认识到了C+的运用是相当广泛的,才拿到题目的时候,我真的不知道该怎么办,但随着慢慢的设计,思路也总算有了,这样才能继续进行下去,这时

12、我才真正认识到了C+的功能原来是那么的多。一个复杂的实验室设备管理系统,经过500-600行的代码就可以完完全全的达到,这是让我非常惊讶的,但相对,如今的C+也是非常难的,这学期学到的一些内容,都是C+的重点,但学下来以后感觉还是很难所以必须先打好基础,基础好了,学什么都会容易很多。这次的程序设计让我重新认识到了C+,这是一门非常重要的科目,我们必须付出很多倍的努力学习它,才能熟练地掌握它。参考资料1郑莉 等编著C+语言程序设计(第三版)北京:清华大学出版社2郑莉 等编著C+语言程序设计(第三版)学生用书北京: 清华大学出版社3李春葆 等编著C+程序设计学习与上机实验指导 北京:清华大学出版社

13、4范辉 等编著Visual C+6.0程序设计简明教程 高等教育出版社5李龙澍C+程序设计实训教程北京:清华大学出版社 6洪国胜 等编著 C+ Builder程序设计轻松上手北京:清华大学出版社7严蔚敏等 数据结构(c语言版) 北京:清华大学出版社,1997年4月第1版。8胡学钢等数据结构算法设计指导北京:清华大学出版社,1999年 第1版。源代码#include#include#include#include#includeusing namespace std;class Node /结点类,用于存放客户的各种信息public: long id; /实验设备编号 string name;

14、/名称 string type; /设备类型string suoshushiyanshi; /实验设备所属实验室string buytime; /购买时间string price; /价格string amount; /库存量string shengchanriqi; /生产日期string shiyongshouming; /使用寿命 string weight; /重量 Node *next; /指向下一结点的指针 Node(long id=000,string nname=noname,string ntype=unkown,string nsuoshushiyanshi=unknow,

15、string nbuytime=unknow,string nprice=unknow,string namount=unknow, string nshengchanriqi=unkown,string nshiyongshouming=unknow,string nweight=unknow );/构造函数,初始化变量;class Link/Link类,把数据以链表的形式存储,链表的每个结点为一个Node对象private: Node *head; /链表的头指针,为Node对象类型的指针public : Link();/构造函数,初始化变量 bool linkIsEmpty();/判断链

16、表是否为空 void linkInsert(Node *newnode);/向链表中插入新的结点 bool linkDelete(int nid);/从链表中删除的结点 void linkClear();/清空链表中数据 void linkView();/查看链表中数据 Node* linkFind(int nid);/在链表中查找id为nid结点,返回指向该结点的指针 Node* getHead();/获取头指针;Node:Node(long nid, string nname, string ntype,string nsuoshushiyanshi,string nbuytime,str

17、ing nprice,string namount, string nshengchanriqi,string nshiyongshouming,string nweight) id=nid; name=nname;type=ntype;suoshushiyanshi=nsuoshushiyanshi;buytime=nbuytime;price=nprice;amount=namount;shengchanriqi=nshengchanriqi;shiyongshouming=nshiyongshouming; weight=nweight; next=NULL;Link:Link() /构

18、造函数,初始化链表为空 head=NULL;bool Link:linkIsEmpty() /判断链表是否为空,空则返回true return(head=NULL);void Link:linkInsert(Node *newnode) /按id值从小到大的顺序,插入新的结点 Node *p1; if(!head)/链表为空的情况 head=newnode; else if(head-id)(newnode-id) /插入到第一个结点的情况 newnode-next=head; head=newnode; else /插入到第二个及以后情况 p1=head; while(1) if(!(p1-

19、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) /删除结点,成功则返回true Node *p; if(head=NULL)/链表为空的情况 return false; if(head-id=nid) /删除的为第一个结点的情况 head=head-next; return true; p=head; while(p-next) /删除的为第二个及

20、以后结点的情况 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 nid) /查找id值为nid的结点,返回该结点的指针 Node *p=head; /没找到符合条件的结点的话,返回的指针值为NULL while(p) if(p-id=nid) break; else p=p-next; return p;void Link:linkView() /显示链表数据 Nod

21、e *p=head; while(p) cout实验设备编号:idendl; cout名称:nameendl; cout类型:typeendl; cout所属实验室:suoshushiyanshiendl; cout购买时间:buytimeendl; cout价格:priceendl; cout库存量:amountendl; cout生产日期:shengchanriqiendl; cout使用寿命:shiyongshoumingendl; cout重量:weightendl; cout*next; Node* Link:getHead() return head;/类Shebei,用于包装Li

22、nk类及菜单操作class Shebeiprivate: Link clink;/Link对象成员 bool k;/记录数据是否被修改public: Shebei(); void ShebeiClear(); void ShebeiInsert(); void ShebeiDelete(); void ShebeiFind();void ShebeiModify(); void ShebeiView(); void ShebeiLoad(); void ShebeiSave(); void Exit();/退出程序 void showMenu();/显示菜单 void showTip();/显

23、示操作提示 void doMenu(char n);/执行相应菜单项功能;Shebei:Shebei() Link();/调用成员对象的构造函数 ShebeiLoad();/从文件中读取数据,创建链表 k=false;/设置数据被修改void Shebei:ShebeiClear() /清空设备记录 clink.linkClear(); cout成功清空设备信息记录!endl;void Shebei:ShebeiInsert() /插入设备记录 Node *p=new Node(); coutp-id; coutp-name; coutp-type;coutp-suoshushiyanshi;

24、coutp-buytime; coutp-price; coutp-amount; coutp-shengchanriqi;coutp-weight; if(!clink.linkFind(p-id) /判断设备信息是否存在 clink.linkInsert(p); k=true; else cout设备编号为id的的设备已存在,插入失败!endl;void Shebei:ShebeiDelete() /删除设备记录 long i; if(clink.linkIsEmpty()/链表为空的情况 cout没有设备记录!endl; else couti; if(clink.linkDelete(i

25、) cout成功删除编号为i的实验记录!endl; k=true; else cout没有找到编号为i的设备!endl; void Shebei:ShebeiFind() /查找某编号的设备记录 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所属实验室:suoshushiyan

26、shiendl; cout购买时间:buytimeendl; cout价格:priceendl; cout库存量:amountendl; cout生产日期:shengchanriqiendl; cout使用寿命:shiyongshoumingendl; cout重量:weightendl; else/指针值为NULL时 cout没有找到编号为n的设备记录!endl; void Shebei:ShebeiModify() /修改某编号的设备信息 long n; Node *p; if(clink.linkIsEmpty()/链表为空的情况 cout没有设备记录!endl; else coutn;

27、 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重量:weightendl;cout请输入新的设备信息endl;coutp-id; c

28、outp-name; coutp-type; coutp-suoshushiyanshi; coutp-buytime; coutp-price; coutp-amount; coutp-shengchanriqi; coutp-weight; else/指针值为NULL时 cout没有找到编号为n的设备记录!endl; void Shebei:ShebeiView() /显示所有设备的记录 if(clink.linkIsEmpty() cout没有设备记录!endl; else clink.linkView();void Shebei:ShebeiLoad() /从文件中读入数据,创建链表

29、Node *p; long nid; ifstream infile(data.txt); if(!infile) cerrnid) /读取客户,直到读空 p=new Node(); p-id=nid; infilep-name ; /读取名称 infilep-type ;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()

版权声明:以上文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如有侵权请立即联系:2622162128@qq.com ,我们立即下架或删除。

Copyright© 2022-2024 www.wodocx.com ,All Rights Reserved |陕ICP备19002583号-1 

陕公网安备 61072602000132号     违法和不良信息举报:0916-4228922