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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

本文(数据结构实习报告.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构实习报告.docx

1、数据结构实习报告数据结构课程设计报告* * * * 班 级: 116102 学生学号: * 实习题目一1.需求规格说明书 设停车场是一个可停放 n 辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停 车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆 车停放在车场的最北端),若车场内已停满 n 辆汽车,则后来的汽车只能在门外的便道上等 候,一旦有车开走,则排在便道上的第一辆车即可开入;当停车场内某辆车要离开时,在它 之后进入的车辆必须先退出车场为它让路,待该辆车开出大门外,其他车辆再按原次序进入 车场,每辆停放在车场的车在它离开停车场时必须按它停留的时间长短交

2、纳费用。试为停车 场编制按上述要求进行管理的模拟程序。2.总体分析与设计 【设计思想】 在内存中实现,无需外存的流处理过程。主要的算法思想是栈和队列的使用。以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入的输入数据序列进行模拟 管理。每一组输入数据包括三个数据项:汽车“到达”或“离去”信息,汽车牌照号以及到达或 离去的时刻。对每一组输入的数据进行操作后的输出信息为:若是车辆到达,则输出汽车在停车场内或便道上的停车位置;若是车辆离去,则输出汽车在停车场内停留的时间和应交纳 的费用(在便道上停留的时间不收费)。栈以顺序结构实现,队列以链表结构实现。【设计表示】【详细设计表示】 主函数开始时要

3、求用户输入停车场的初始大小,然后对进入的车辆进行管理,如果是进入,调用添加函数,此函数中定义的规则是如果停车场如果没有满就加到停车场栈中,如果停车场已经满了,就添加到走道队列中。处理完添加函数后while循环调用次过程。同理,如果是车辆要出去,就调用删除函数,如果删除后走道上有车在等待车位就将走道上的车辆根据先进先出的规则压到栈中。处理完删除函数之后也while循环调用次过程。只有当用户输入结束的时候此循环才会结束。3.编码 1.输入A表示的是添加,输入D表示删除,输入E表示结束,那么要是用户不小心输入了其他的一个字母怎么办呢? 在while循环中最开始进行判断的并不是输入的是否为ADE而是输

4、入的是不是不是ADE中间的任何一个,这时候令输入无效,用户需重新输入。此时的输入作废。2.添加的时候如果是栈没有满,这时应该添加到栈中去,储存进入时间和车号,但是如果只是停在走道上需不需要这些数据呢?这里要不要抖没有关系,因为在这里如果要了的话在后面闪出部分走道上的车子重新进入的时候就重新记录一遍车子的进入时间,避免在走道上的时间也要被收费。3.删除的时候将此时的时间减去车子这个数据对象的进入时间就是时间差,根据规定的单价计算停车费用。但是如果走道上有车子的时候他的进入时间呢?处理时一定的,一定要更新,否则车子在走道上的时间也总算在停车场的时间这是不对的。4.如果在停车场中要出去的车是先进来的

5、车子,则表示比他后来的车要先出去那此时的算法呢?答案是也将前面的车先存在一个栈中,等向后面的车子先出去后在出栈重新压栈。4.程序算分分析【运行结果】5.小结【改进设想】用类的思想,本题我还是沿用的过程思想,对各个过程处理好就出了结果,尽管结果没有错,但是和面向对象的思想不是太符合,所以希望可以用个停车场这一个类来处理问题。【体会】有时候在调试的时候的很小的一个结果和预想的不符就是很大的思想问题,比如我调试的时候最后一步有时候钱算的不对,就是添加删除时的时间没有处理正确,所以,错误不在小。要知道为什么会出这个错。编程的时候重要的是提前把思路理好。6.附录class Car public: int

6、 carno; /车牌号 int intime; /时间 ; int n; /停车场容量 int no; /车牌号 char situa; /状态 int tim; /进出站时间 int index=1; /车的序列 int preindex=index; /跟踪index coutn; coutendl; Stake carpark(n); /停车场栈 Stake tempstake(8); /临时车站 LinkedQueue passage; /走道队列 Car car7; /车对象 6个 /*for (int i=1;i=6;i+) cari.carno=i; */ while (tru

7、e) coutsitua; if (situa!=A & situa!=D & situa!=E) cout错误状态!请输入 A ,D 或者 E!endl; coutsitua; if (situa=A) coutno; couttim; if (index=2) cout位置:indexendl; else cout车道上endl; carno.intime=tim; carno.carno=no; index+; /如果栈满就加到队列中 if (carpark.IsFull() passage.Add(no); / /如果栈没有满就压栈 if (!carpark.IsFull() carp

8、ark.Add(no); /出车站 if (situa=D) coutno; couttim; cout停留时间:tim-(carno.intime)endl; cout应缴费用:(tim-(carno.intime)*2 元endl; index-; preindex-; /把no以前的car都放到tempstake里面,再删除no,在放回 int cp_delete; int tcp_delete; int pas_delete; int waste; while(carpark.Top()!=no) carpark.Delete(cp_delete); tempstake.Add(cp_

9、delete); carpark.Delete(waste); while (!tempstake.IsEmpty() tempstake.Delete(tcp_delete); carpark.Add(tcp_delete); /如果走道有车就加到栈顶 if (!passage.IsEmpty() & !carpark.IsFull() passage.Delete(pas_delete); /1 carpark.Add(pas_delete); cp_delete=0; tcp_delete=0; pas_delete=0; waste=0; if (situa=E) break; cou

10、tendlendl; cout感谢使用本程序,祝您新年快乐!endl;实习题目二1.需求规格说明书 人们在日常生活中经常需要查找某个人或某个单位的电话号码,本实验将实现一个简单 的个人电话号码查询系统,根据用户输入的信息(例如姓名等)进行快速查询。2.总体分析与设计 【设计思想】本题要求的是做一个通讯录,由于所需要的数据量比较大,所以考虑在外存中进行处理,这里用的是txt文件。当然本来想用数据库的,但是水平不到家。所以放弃了。新建一个数据类型,包括姓名,固定电话,移动电话,电子邮箱。为了实现对电话号码的快速查询,可以将上述结构数组排序,以便应用折半查找,但是, 在数组中实现插入和删除操作的代价

11、较高。如果记录需频繁进行插入或删除操作,可以考虑采用二叉搜索树组织电话号码信息,则查找和维护都能获得较高的时间性能。【设计表示】【详细设计表示】 设置四个选项,0、1、2、3分别代表退出、查询、插入、删除。根据所需要的功能做出操作。初始数据储存在txt文本中。如果选择退出则退出系统,如果选择插入则需填写姓名,电话,手机,邮箱信息。根据名字按照二叉搜索树的形式组织插入,如果选择删除,根据名字的次序在搜索树中删除。如果是查询也根据二叉搜索树的形式删除。3.编码1.名字的判断大小,因为组织二叉搜索树的时候需要对插入和删除做优化,所以需要对名字的大小问题作出比较。解决的时候是通过操作符重载完成的。开始

12、的时候不知道汉字怎么比较大小。后来通过请教了解到汉字可以直接比较大小。大于号的重载就是这个人的名字大于另外一个人的名字。2二叉树的插入,我拷的是以前的代码其实自己重写一遍话的时间还少一些,因为pp和p搞反了。后来问了张唯老师才在讲的时候发现这个问题。3.删除的时候在内存中的二叉搜索树中删除很容易但是文本中的内容并没有变,所以在内存中处理完了之后需要重写文本。开始的时候是先删除所有的文本内容,在重新全部重写。但是后来发信啊这样内存的开销特别大,而且不容易实现,后来是删除之后直接就在文本中输出。发现重新输出的时候文本会重新更新。. 4.程序算分分析【运行结果】5.小结【改进设想】Txt中的信息没有

13、对齐。如果可以的话用数据库或者excel做可能会清晰一些。还有就是如果文本中的信息没有8条的话是会出错的。界面不好。用mfc会好一些【体会】直接烤以前的代码如果有不适合的话会很麻烦,如果代码不很长的话还是抄一遍吧。那样会思路清晰一些。6.附录ifstream in(Tele.txt); /建立流对象 BSTree bstree; int num; int total=8; for (int i=0;iTelei.nameTelei.mobilnumberTelei.phonenumberTelei.email; ; for (int j=0;jtotal;j+) /做二叉树 bstree.In

14、sert(Telej); while(true) cout*endl; cout*如果要退出请按0*endl; cout*如果要查询请按1*endl; cout*如果要插入请按2*endl; cout*如果要删除请按3*endl; cout*num; if (num=0) /退出 break; if (num=1) /查找 string temp_name; TelNumber menber,find_member; couttemp_name; bstree.Search(temp_name,find_member);/根据名字找 couttemp_name的电话为:find_member.

15、phonenumberendl; couttemp_name的手机为:find_member.mobilnumberendl; couttemp_name的邮箱为:find_member.emailendl; if (num=2) /插入完成 ofstream out(Tele.txt); TelNumber mem2,insertmen,delmen; int num2=0; coutmem2.name; coutmem2.phonenumber; coutmem2.mobilnumber; coutmem2.email; bstree.Insert(mem2); Teletotal=mem

16、2; total+; while (num2total) /重新写txt if (Telenum2!=mem2) bstree.Delete(Telenum2,delmen); outsetw(5)leftdelmen.namesetw(20)rightdelmen.mobilnumber rightsetw(20)delmen.phonenumbersetw(30)rightdelmen.emailendl; if (Telenum2=mem2) bstree.Delete(Telenum2,delmen); outsetw(5)leftdelmen.namesetw(20)rightdel

17、men.mobilnumber rightsetw(20)delmen.phonenumbersetw(30)rightdelmen.emailendl; num2+; for (int j=0;jtotal;j+) bstree.Insert(Telej); if (num=3) /删除 string temp_name0; char yorn; ofstream out(Tele.txt); TelNumber menber0,delete_member; couttemp_name0; for (int t=0;ttotal;t+) if (Telet.name=temp_name0)

18、menber0=Telet; cout您真的要删除吗?endl; while (yorn!=y & yorn!=n) coutyorn; if (yorn=y) int tempnum=0; int nmo=0; TelNumber here100; while (tempnumtotal) if (Teletempnum!=menber0) bstree.Delete(Teletempnum,delete_member); herenmo=delete_member; outsetw(5)leftdelete_member.namesetw(20)rightdelete_member.mob

19、ilnumber rightsetw(20)delete_member.phonenumbersetw(30)rightdelete_member.emailendl; nmo+; if (Teletempnum=menber0) bstree.Delete(Teletempnum,delete_member); tempnum+; /重新插入 for (int e=0;e=nmo;e+) bstree.Insert(heree); total-; cout已删除成功!endl; 实习题目三1.需求规格说明书假定文本文件 A1.txt 中是我校所有参加南望山庄二期挑房职工的信息,请编写程序,读

20、 出文件中的内容,再按挑房的先后次序排队后将排序号和姓名以文本方式存放到文件A2.txt 中。 排队原则: 先按职称排,同职称按分房工龄排,同工龄按年龄排。2.总体分析与设计【设计思想】 由于测试数据是在文本中的数据,所以处理起来需要用到输入输出流。将已经给好的a1.txt.中的数据在内存中处理完毕之后就重新输出到另外一个a2.txt中。【设计表示】【详细设计】 建立流对象两个,第一个是输入流,一个是输出流。将给输数据流读到内存中,调用排序函数,这里不能用选择排序,因为选择排序的话要写三个不同的找到最大值函数。根据三个不同的因素来排。所以选择冒泡排序。拍完之后在输出就行了。3.编码1.开始的时

21、候建立流对象忘记了。看以前的数的时候也不知道,因为以前这里也没有学通。现在做到时候是叫同学叫我怎么做流的技巧的。2.排序算法。开始的时候嫌冒泡太麻烦。要写好多。想找个简单的但是后来发现就这个用的方便。其他的都需要重载函数。太麻烦。3.调整间距,在用了一个left或right之后只能管一下,在下一个操作符之后的地方前面的限定就不起作用了。需要重新声明左对齐与右对齐。4.程序算分分析【运行结果】5.小结 【体会】这次实习最大的收获就是学会了初级的输入输出流处理,程序大多数是对输入输出的处理,应付不同的数据组织形式。需要掌握多种技术。 6.附录class Workerpublic: int numb

22、er; /职称编号 int workage; /工龄 int age; /年龄 char name20; /姓名;void bubsort(Worker temp,int n) int a,b; Worker tempwork; /根据number排序 for(a=1;an;a+) for (b=1;btempb-1.number) tempwork=tempb; tempb=tempb-1; tempb-1=tempwork; /根据工龄排 for (a=1;an;a+) for (b=1;btempb-1.workage) tempwork=tempb; tempb=tempb-1; te

23、mpb-1=tempwork; /根据年龄排 for (a=1;an;a+) for (b=1;btempb-1.age) tempwork=tempb; tempb=tempb-1; tempb-1=tempwork; int main(int argc, char* argv) ifstream in(123.txt); /定义输入流,源txt ofstream out(ok.txt); /定义输出流,目标txt int width=40; char information40; in.getline(information,width); /把宽度为width的字符放在info中 outinformationendl; /在out中输出info Worker worker505; for (int i=0;iworkeri.nameworkeri.numberworkeri.workageworkeri.age; bubsort(worker,505); for (int index=0;index505;index+) outleftsetw(7)workerindex.namesetw(8)rightworkerindex.numbersetw(8)workerindex.workagesetw(9)workerindex.ageendl;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1