QuadTree c++实验结果

1. 实验数据以及实验环境

数据集一:City of Oldenburg (OL) Road Network

结点个数:6105

数据集二:Road Network of North America (NA)

结点个数:175813

实验环境:windows7VS2012

2. 实验结果

2-1 实验结果

数据集

结点个数

QuadTree

结点数

树高

最大宽度

创建(ms)

查询(ms)

1

6105

19773

14

6104

194

16

2

175813

800709

14

199048

6814

640

3.实验分析

        数据一与数据二区域均为(0.0, 0.0)~(10000.0, 10000.0),因此数据集二中的数据比数据一密集的多。C++中使用的float最多有7位有效数字,因此当点密集时将不能够继续划分(即使double也不能解决)。

        刚开始建立的QuadTree直到每个QuadTree结点只包含一个数据或所包含的区域没有数据,用数据集一测试没有问题,且可以准确查到每一个存在的节点。但对于数据集二却因没有足够的内存空间而不能够将这样的QuadTree创建(内存消耗急剧增加,创建850多万个结点时失败)。为了进一步减少空间消耗,将stack容器替换成自己写的QuadTreeNodeStack,但当结点个数达到1700多万时崩溃。

        针对以上问题,修改后的QuadTree的叶子节点面积小于1.0*1.0时即使包含多个数据也不再划分,问题得到解决。

4. 实验心得

4.1存在的问题

(1) 刚开始写代码时想到哪里写到哪里,结果忙了半天却只能重新写。

(2) 对问题考虑的步骤全。比如在数据集一上能够测试,但数据集二却完全不能用,只能花时间来修改数据结构。

4.2总结

动手写代码之前一定要:

(1) 认真分析数据结构的特点,尤其特殊情况;

(2) 设计好每种数据类型,包括属性、方法等;

(3) 认真了解使用的各种库函数。

 

5. 源码下载:

代码1:http://download.youkuaiyun.com/detail/woniu317/6931519

代码2:http://download.youkuaiyun.com/detail/woniu317/6934665

 

为了方便,把代码放在Word里面了,每次上机实验的题目代码都在。 第一次: 对如下多项式编写类定义: + + +…+ 其中,n为多项式的次数。完成如下功能: (1) 可存储任意大的多项式(提示:可用动态数组实现)。 (2) 定义构造函数、析构函数、拷贝构造函数。 (3) 包含一个static成员存储定义的多项式的数量。 (4) 定义一个成员函数输出多项式。(可参照-x^4-6x^3+5格式输出) (5) 定义一个成员函数计算多项式的值。 (6) 写main函数测试类的功能。 (7) 采用多文件实现。 考虑:哪些成员函数可以声明为const. 第二次: (8) 重载“+”运算符,实现两个多项式相加。 (9) 重载“-”运算符,实现两个多项式相减。 (10) 重载“*”运算符,实现两个多项式相乘。 (11) 重载“=”运算符,实现两个多项式的赋值运算。 考虑:把其中某个运算符重载为友元函数。 第三次: C++的一般编译器都定义和封装了字符串功能,请模仿定义string类的实现,可以实现并支持如下功能: (1)string s = “吉林大学”; (2)string t = s; (3)string m; m = t; (4)m.legnth() 函数测量字符串的长度 (5)m.cat(string const &)连接字符串 第四次: 我公司为仪器生产企业,目前生产摄像机和行车记录仪两种产品,分别销售给用户。 摄像机包含摄像、图像质量设定、编码算法等属性。 将摄像机增加相应芯片(具有操作菜单、自动拍摄、车速传感器、源代码等功能)后,形成一个行车记录仪。 要求: 设计摄像机类,并请根据下列不同的功能要求,采用不同的继承方式,设计行车记录仪类,并添加测试代码,体验不同继承方式下的成员访问属性。(类设计时可根据需要自行添加数据成员和其他成员函数。) (1) 行车记录仪的芯片可以使用摄像机的摄像、图像质量设定功能。 行车记录仪用户可以操作行车记录仪的操作菜单和摄像机的摄像功能。 (2)行车记录仪的芯片可以使用摄像机的拍摄、图像质量设定功能。 行车记录仪用户仅仅可以操作行车记录仪的操作菜单。 (3) 行车记录仪的芯片可以使用摄像机的拍摄、图像质量设定功能。 行车记录仪用户仅仅可以操作行车记录仪的操作菜单 同时其他公司购买行车记录仪,因该公司也用于销售,不得泄露其全部内容 课后: (1)采用组合方式设计行车记录仪类,增加相应测试代码,体验继承和组合的关系。 (2)分别为继承和组合方式下为各类添加构造函数、析构函数,增加相应测试代码,体验对象的初始化和构造顺序。 (3)将摄像机类和行车记录仪类功能相近的函数(如拍摄、编码等功能函数)设为同名函数,增加相应测试代码,体验同名函数覆盖。 (4)为我公司建立一个多态的产品类层次结构,使用抽象类,测试时,创建一个基类指针的容器,通过基类指针调用虚函数,体验多态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值