《算法与数据结构》 实验报告.doc
《《算法与数据结构》 实验报告.doc》由会员分享,可在线阅读,更多相关《《算法与数据结构》 实验报告.doc(15页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、算法与数据结构实验报告班级_ 姓名_ 学号_实验1:线性表的建立及操作(6学时)问题描述 定义一个图书类和一个书库类。图书类包括图书编号、书名、作者(只考虑第一作者)、定价等属性;书库类包括一个指向图书链表的头指针以及操作链表的相关函数。这两个类的定义如下:class Book int BookNumber; /图书编号 char BookName50; /书名 char AuthorName30; /第一作者姓名 double Price; /定价 Book *next; /指向下一个图书对象的指针public: void print(); /输出图书的所有属性 ;class BookSto
2、reBook *book_head; /图书链表的头指针 public:BookStore(); /创建书库对象,图书链表的头指针为空Book* createBook(); /创建一个图书对象void insertBook(Book *b); /按定价从高到低将图书对象插入到图书链表void deleteBook(int booknumber); /从链表中删除图书编号为booknumber的图书double getTotalPrice(); /获得该书库中图书的定价之和int getBookCount(); /获得该书库中图书的数目Book* findBook(int booknumber)
3、; /按照图书编号查找图书,并输出图书信息Book* findBook(char *str); /按照书名或者作者查找图书,并输出图书信息void print(); /输出该书库中所有图书信息BookStore(); /释放书库对象 . /根据需要设置其它方法;实验目的(1) 熟悉面向对象程序设计中链表结点的定义以及链表的建立过程;(2) 掌握链表的基本操作,包括:遍历链表、插入结点、删除结点等。实验内容及要求(1) 在Visual C+ 6.0环境下,编写程序实现图书类和书库类;(2) 在主函数中建立一个图书链表,并测试图书类和书库类中的相关方法。算法与数据结构实验报告班级_ 姓名_ 学号_
4、实验2:线性表的应用(6学时)问题描述 通过单链表实现整数集合的交()、并()、异或(XOR)运算。其中:两个集合A和B的异或运算的结果是属于A且不属于B的元素和属于B且不属于A的元素。实验目的(1) 熟练掌握链表的基本操作;(2) 运用链表解决实际问题。实验内容及要求(1) 编写程序,设计结点类,通过链表描述整数集合;(2) 在主函数中建立两个递增排序的整数链表,对这两个链表依次执行交、并、异或运算,并输出相应结果;如果运算结果为“空”,则输出“NULL”;(3) 由于同一个集合中不能同时存在两个相同的元素,因此在一个链表中不应存在数值相同的两个结点;(4) 当执行集合的异或运算时,不开辟新
5、空间,只在原有的两个链表上进行操作。示例输入/输出示例输入:105 15 7 9 100 -43 18 9 -100 66156 5 200 -9 88 7654 0 16 22 -12 -100 365 1 8 123示例输出:第一个集合共有9个元素,分别是:-100 -43 5 7 9 15 18 66 100第二个集合共有15个元素,分别是:-100 -12 -9 0 1 5 6 8 16 22 88 123 200 365 7654两个集合的交共有2个元素,分别是:-100 5两个集合的并共有22个元素,分别是:-100 -43 -12 -9 0 1 5 6 7 89 15 16 18
6、 22 66 88 100 123 200365 7654两个集合的异或共有20个元素,分别是:-43 -12 -9 0 1 6 7 8 9 1516 18 22 66 88 100 123 200 365 7654算法与数据结构实验报告班级_ 姓名_ 学号_实验3:栈和队列的应用(12学时)问题描述 设停车场是一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆车停放在停车场的最北端),若停车场内已停满n辆汽车,则后来的汽车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入停车场;
7、当停车场内某辆车要离开时,在它之后进入的车辆必须先退出车场为它让路,待该辆车开出大门外,其他车辆再按原次序进入车场;每辆停放在车场的车在它离开停车场时,必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。实验目的(1) 理解栈(先进后出)和队列(先进先出)的工作特点;(2) 掌握栈结构的构造方法以及栈的基本操作(出栈、入栈);(3) 掌握队列的构造方法以及队列的基本操作(出队列、入队列);(4) 运用栈和队列解决实际问题。实验内容及要求(1) 以栈模拟停车场,以队列模拟停车场外的便道,按照从终端读入的输入数据序列进行模拟管理。每一组输入数据包括三个数据项:(i) 汽车“
8、到达”或“离去”信息,(ii) 汽车牌照号码,(iii) 到达或离去的时刻。(2) 对每一组输入数据进行操作后的输出信息为:若是车辆到达,则输出汽车在停车场内或便道上的停车位置;若是车辆离去,则输出汽车在停车场内停留的时间(单位是小时)和应交纳的费用(在便道上停留的时间不收费),假设停车费为每小时m元。(3) 栈和队列均采用链表结构实现。(4) 提示:需另设一个栈(也用链表结构实现),临时停放为给要离去的汽车让路而从停车场退出来的汽车。栈中每个元素表示一辆汽车,包含两个数据项:汽车的牌照号码和进入停车场的时刻。示例输入/输出设n=2,m=5,则输入数据为:2 5A 1 10A 2 15D 1
9、20A 3 23A 4 28A 5 31A 6 33D 2 45D 4 70E其中:A表示到达(Arrival);D表示离去(Departure);E表示程序结束(End)。输出数据为:汽车1停靠在停车场1号位置汽车2停靠在停车场2号位置汽车1停车13小时,缴纳停车费65元汽车3停靠在停车场2号位置汽车4停靠在便道的1号位置汽车5停靠在便道的2号位置汽车6停靠在便道的3号位置汽车2停车30小时,缴纳停车费150元汽车4停靠在停车场2号位置 (说明:汽车4进入停车场的时间为汽车2离开的时间)汽车4停车25小时,缴纳停车费125元其中:停车场从北至南的序号依次为1(栈底)n(栈顶);便道上的停车序
10、号从1(队列头)开始,往后依次增一。选作内容(1) 等候在便道上的汽车可以直接从便道上开走,此时排在它前面的汽车要先开走让路,然后再依次排到队尾,并使得原来排在前面的汽车仍然排在前面。(2) 汽车可有不同种类,则他们的占地面积不同,收费标准也不同,如:1辆7座客车和1.5辆小汽车的占地面积相同,收费为每小时3元;1辆卡车占地面积相当于2辆小汽车的占地面积,收费为每小时4元;一辆公共汽车占地面积相当于3量小汽车的占地面积,收费为每小时6元等等;因此,等候在便道上的汽车无法可能无法进入停车场(假设停车场总面积为M,当前停车场的空余面积小于汽车所需占地面积)。算法与数据结构实验报告班级_ 姓名_ 学
11、号_实验4:面向数字图像的Huffman编/译码器的设计与实现(1215学时)问题描述 “Huffman-树”不仅能对文本数据进行编码、译码,提高文本数据的传输效率,同时它也能对多媒体数据(如:数字图像、视频等)进行编码、译码,从而实现多媒体数据的压缩存储。目前,在Web互联网上广泛使用的JPEG图像格式就采用了Huffman编码,与其他图像格式(如:BMP、TIF等)相比,同一副图像采用JPEG格式时所需的存储空间是最少的。在这个实验中,请设计一个Huffman编/译码器,并模拟数字图像的压缩存储(编码)和解码显示(译码)的过程。实验目的(1) 掌握“Huffman-树”的构造过程;(2)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 算法与数据结构 算法与数据结构 实验报告 算法 数据结构 实验 报告
限制150内