请用C++编写此程序, 并编写测试程序进行测试?

请用C++编写此程序, 并编写测试程序进行测试?,第1张

你好!测试程序负责给编写好的程序提供样本数据,自动收集运行结果,并根据结果作出反馈。

测试程序可以单独写,也可以做为模块整合在源程序中。

像我们熟知的debug语句,就是测试的最简单例子。在没有“断电查看”这一功能之前,为了监测程序每步执行后变量的结果,往往加入一些输出关键变量的语句。

例如以下程序:

#incldue<iostream>

using namespace std

#define DEBUG

int main(){

int n

#ifdef DEBUG

cout<<n<<endl

#endif

n = 3

cout<<n<<endl

return 0

}

此处DEBUG的作用是查看未初始化的变量n的值。通常会显示-89******00(0xcccccccc).

一般这样的语句还会出现在对指针进行 *** 作之后,用debug语句输出指针所指向内存的内容等。

这只是测试程序的一个功能。正如前面提到的,测试程序应该提供数据以检测程序的健壮性和安全性,以及用海量数据对执行效率进行检验等。

测试数据的选择有以下几个要点,分别检测程序的不同特性:

@ 尽可能包括输入集合内所有可能出现的元素,观察程序能否给出正确结果。(Authenticity)

比如:有一个程序输入给定迷宫平面图,要测试出最短路径长度。那么输入的迷宫应该包括各种可能:有通路的和没有通路的,有死胡同的和没有的,有回路的(避免搜索时出现死循环),出口在左上角,右上角的等,都要考虑进去。程序应该对每种情况都做出正确的反应。

@ 注意测试极端情况以及临界情况。(Security)

这是为了检测程序的健壮性,用户不可避免地会做出不合法的举动,程序需要有足够的防护强度来应对这些意外。

比如:如果编写了一个简易的计算器,那么一定要检查除数为0的情况;一个程序的功能是将一片文档的内容链接到另一个文档内,那么一定要检查自己链接自己的情况;等等。

@ 注意输入数据的规模以及随机性。(Efficiency)

衡量程序效率的标准应该考虑大规模数据下的表现。数据需要有足够的随机性以避免意外情况。

比如:比较几种不同排序算法的效率时,选用的数据应该是随机顺序的。在顺序数据的情况下:冒泡算法显然比快排还快,但这是偶然情况。

@ 如果有可能,还可以检测程序的通用性及扩展性(Versatility &Compatibility)

好的程序应该易于扩展,可利用价值高。大多数软件都在不停的打补丁,而不是推倒重写。

测试程序一般无法直接检测这两种特性。然而,测试中出现的错误有时可以帮助我们提升程序的质量。

我曾经写过一个类似于美图秀秀的图像处理程序,C++写的,相当粗糙。输入还要用命令行控制。当时我用各种图片进行了测试,包括纯色的,有明显背景色调的,以及完全混乱的噪声点。前面的图片表现都很好,但处理最后一张图片时程序抛出了异常——经过检验发现,我的处理程序是基于24位图片写的,而最后一张图片是32位的。类似的情况还有32位系统和64位系统下程序运行的问题等,在此就不赘述了。

要编写测试程序,一般分为两个模块:数据生成和结果检测。

测试程序的第一部分将生成的数据写入一个文件,让程序读取文件并运行后,再将结果写入另一个文件,之后由测试程序的第二部分比对输出文件和标准答案。

对于检测健壮性的测试程序,只需有第一部分即可,待检测程序在处理数据时如果发生异常,就根据结果作相应的修改。

测试效率的程序,可以在待检程序内加入计时模块。具体写法如下:

#include<ctime>

#define CHECK_TIME

int main(){

//....intput

#ifdef CHECK_TIME

clock t start = clock()

#endif

#ifdef CHECK_TIME

cout <<"Execution Time: " <<clock() - start <<" ms." <<endl

#endif

嗯,就是这么多啦,希望对你有帮助!

这是要做OJ吗……以下用Linux角度考虑。

1.第一步和第二步有何不同?

2.首先编译工作可以用system调用make脚本。一般限定只有一个代码文件,所以makefile是固定的,产生的可执行文件也是固定的。通过限定makefile,可以限制编译时对系统库和网络库的调用。

3.用>和<在调用可执行文件时实现输入输出重定向。输出的文件名和标准输出结果都是预定的。

4.将实际输出文件和标准输出文件进行比较。采用类似Special Judge的方式,专门设计一个程序同时读入两个输出文件,逐行比较。

5.为了实现定时功能,可以用子线程方式运行程序,主线程负责检测时间。时间到了看看子线程有没有返回,就知道是否TLE。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12050261.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存