昨天碰到一道题目,样例过了,但是一交就wa,所以就想着能不能找出错的测试数据,又因为之前一直听说可以用对拍来检测程序正确性,所以昨天就看了别人博客学了下对拍。
接下来介绍下简单的bat文件对拍,用c++程序对拍的暂时还不会 。
整体步骤: 首先对拍,需要有产生测试数据的程序,暴力方法的程序(或者已ac的程序),需要对拍的程序,先写好这些程序,再分别编译生成可执行的exe文件,然后就是新建一个data.txt(存放测试数据),一个baoli.txt(存储暴力程序输出的数据),一个test.txt(存储对拍程序输出的数据),最后再新建一个dp.bat文件(可以关闭Windows的隐藏文件后缀名选项,然后新建一个txt文件,将后缀改成bat即可),然后在bat文件里面编辑数据输入输出和文件匹配的代码就可以,这个有模板,照着套就行。最后将所有文件和bat文件放在同一个的位置,双击bat文件运行对拍程序。
简单的产生测试数据的程序(以hdu4135示例)
| |
(当然还可以写随机生成图,树等数据结构,算法竞赛进阶指南后有此介绍)
然后暴力程序代码和要对拍的程序代码正常写即可,没有什么限制。
生成好三个可执行exe文件,再创建好存储输入输入数据的txt文件,再就是建立bat文件。
鼠标右键,点击编辑选项,输入下列模板(文件名改成自己的)
| |
代码简单解释下 @echo off 关闭系统提示信息,不关会让对拍过程很混乱。 :loop 循环执行下面的过程 <,> 输出,输入数据 fc 比较两个文件 if not errorlevel 1 goto loop 如果执行fc后得到返回值为0(两文件相同)则继续进入循环过程 否则pause(暂停) 最后可以按任意键goto loop继续进入循环。 ctrl c可强制退出循环
对拍过程中比对到答案不同,会暂停对拍,然后data.txt,ac.txt和test.txt存储的就是答案不同的那一系列数据。