OI生成随机题目数据,测试点集锦【C++】【有待完善】

本文介绍了如何使用C++生成OI竞赛的随机数据,包括基础数据模板如A+B问题,图论数据模板如随机生成树和连通图,以及随机数生成、文件输入输出的基本操作。通过实例讲解数据代码的编写,帮助初学者掌握出题技巧。
摘要由CSDN通过智能技术生成

0x00 前言

这篇文章是蒟蒻为了能使后来的 OIER 们可以更好的搞事情 为大家带来更优质的题目以及更好的写出合理的对拍程序,本蒟蒻在此写了一篇并不完善的文章,总结了出各种数据的代码;

各位Dalao若有更好的办法可以评论,以帮助蒟蒻更好的完成这篇文章,蒟蒻目前的方法其实有点笨,每次都需要手动改文件输入输出的输出文件名;

0x01 基础知识框架

在涉及到题目数据生成之前,要首先学会C++中的伪随机数生成;(不然就只能手打数据了

标程和数据代码

在OI中,一个完整的测试点由输入数据(.in)和答案数据(.out/.ans但是这个得看每个OJ的配置,洛谷是.out文件)组成,其中,输入数据由数据代码随机生成并储存,答案数据由出题人的正确代码,即标程从输入数据中读入,在处理成答案输出储存;

这里我们重点讲的是数据代码,因为标程就是我们平时做题的AC代码,没有本质上的区别;

函数

c++中的伪随机数函数是一个叫做C的库函数,注意,rand()需要头文件 #include<stdlib.h>这里蒟蒻用的是c++的万能头文件#include<bits/stdc++.h>

这个函数会返回一个整型数据(具体因种子而定,一般来说,int是32767,unsigned int是65535),因而基本用法如下:(当然也可以直接输出)

 int num=rand();
 printf("%d",num);

具体用法

但是,当你用这段代码进行随机数输出时,你会惊人的发现他每次运行输出的“随机数”都是同一个数,为什么?

因为刚刚说过,rand()是一个伪随机数,它需要一个种子,这个种子默认为0,所以每次输出会一模一样;因而,为了达到目的,我们需要引入一个设置种子的函数 srand(种子(一个整数),但是,srand()设置的种子一样,那么rand()取到的随机数也会一摸一样,可是我们不能每次为srand()函数设置种子,所以我们需要一个活动的值,比如time()函数返回当前时间,这也是当今主流的写法;

所以就有了以下两种写法,但要注意一点srand()的赋值应当在程序中只有一次或两次赋值程序运行时间大于1s,不然每次随机数会一模一样:(第二种Dev-C++6.5本蒟蒻实测可以过,报错的话应该是个编译器之间有差异)

srand(time(0)); 
int num=rand();
srand((unsigned)time(NULL));
int num=rand();

但是,有的时候,会有数据范围的限制,这时候我们就需要取模来限定他的大小了;比如在我们需要 [ l , r ] [l,r] [l,r]这个区间中的随机数,怎么办?其实很简单,我们先生成一个随机数num,再把这个num对于 ( r − l + 1 ) (r-l+1) (rl+1)取余,最后加上 l l l就可以了;

证明:在num取余之后,它的值在 [ 0 , r − l ] [0,r-l] [0,rl]之内,在加上 l l l后,num属于区间 [ 0 + l , r − l + l ] [0+l,r-l+l] [0+l,rl+l]等价于 [ l , r ] [l,r] [l,r],这就证明了这个算法的正确性;

其实现如下:

//注意,在函数外面应当提前写上srand((unsigned)time(NULL))或srand(time(0)) :
int newrand(int l,int r){
   
	int num=rand();
	return (num%(r-l+1)+l);
}

文件输入输出

一般c++的输出是在控制台中完成,但是在出数据的时候,我们就不可以输出到控制台中了(比较慢,而且不可以一步到位),因而我们需要一个可以吧输出或是输入弄到文件中的代码,即 freopen,代码格式如下:

  • 输入:freopen("你的文件名.文件后缀名","r",stdin);
  • 输出:freopen("你的文件名.文件后缀名","w",stdout);

(想必大家都很熟悉这个臭名昭著的在比赛里面不写爆零的函数了 谁没爆过

这样,我们就掌握了基础知识,可以进行下一步了;

0x02 基础数据模板

P1001 A+B Problem

wings是一款用于单元测试测试用例驱动框架自动生成工具,这款工具主要是全自动生成单元测试驱动代码与测试数据。解决做单元测试耗时耗力,编写难度大等问题。提升开发和测试效率。 特: (1) 程序参数深度分析问题 Wings通过编译器底层技术,将输入的源文件,按照函数为单位,形成模块对象。对象中包含函数的输入参数,返回值类型等信息,供驱动函数模块和测试用例模块使用。每个文件作为一个单元,针对其中的每个函数的每个参数进行深度解析,对于嵌套类型,复杂类型等都可以实现精确的解析和分解,将复杂类型逐层讲解为基础数据类型,并产生参数结构的描述文件(PSD)。 (2) 函数驱动自动生成模块 依据PSD文件的格式信息,自动生成被测源程序的所有驱动函数,单元测试过程不再依赖开发人员手动编写测试函数,只需将生成的驱动函数和被测源文件一起编译,即可执行测试并查看测试结果。测试驱动自动生成程序基于PSD描述,全自动构建驱动被测程序运行的所有参数,必须的全局变量,并可根据复杂变量的层级结构产生结构化的测试驱动程序,可以节省大量的单元测试用例的编写时间。 (3) 测试数据自动生成与管理 用于自动生成测试数据,测试数据与被测函数提取的信息相互对应,数据以一定的层次逻辑关系存 储在json文件中。数据和经过分解和展开后的数据类型是一一对应的。这些数据用户可以根据业务要求随意边际,并且用json文件进行结构化,层次化展示,非常的清晰。其中的测试数据包括全局变量值、被测函数调用时的参数值。 优: 1. 可以为任意复杂参数结构C语言开发的系统全自动生成测试驱动程序 2. 可完成对于被测试函数的参数进行多层编译解析,并完成复杂参数赋值的代码的自动生成。 3. 支持被测函数引用的全局变量的分析和自动赋值程序的生成。 4. 能够区分系统变量和用户变量,对于复杂的系统变量可由用户自定义赋值模板。 例如File类型,而不是把复杂的系统变量全部展开。 5. 支持多层次的可视化的数据表格来对变量进行赋值,而无需关注驱动程序本身。 数据表格可以表达任意深度和多层次的数据关系,用户只需要对表格数据进行编辑,自动生成的驱动程序会自动完成表格数据的读取和参数赋值的构造过程。 6. Wings支持所有C语言的数据类型(基础类型,结构体,指针,数组,枚举等)以及高层级数据结构。 例如链表的分析和对应的驱动和数据表格框架的生成。 7. Wings生成的代码与人工写的非常相近,可读性强,自带注释和按照层次的缩进和代·码编排。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值