快速对拍流程

Posted mandy-h-y

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了快速对拍流程相关的知识,希望对你有一定的参考价值。

快速对拍流程

By admin



 

Part 0 写在前面

教练的对拍教程

原文链接:快速对拍流程

为我们亲爱的子方疯狂打call

他太强了

 


 

Part 1 新建对拍.bat

1.新建一文本文件,将文件名改为"对拍.bat"

2.分别写好makedate.cpp,暴力.cpp,正解.cpp三个文件

3.把文件输入输出注释掉,均为键盘输入,屏幕输出

4.生成相应exe文件

5.对拍.bat文件:

:begin
makedata>in.txt
暴力<in.txt>out.txt
正解<in.txt>out2.txt
fc out.txt out2.txt
if not errorlevel 1 goto begin
pause

 


 

Part 2 运行对拍.bat

双击对拍.bat,即可进行暴力和正解2个程序的相互验证

当输出文件不一致时,会退出,否则一直进行

在bat文件中:

begin为标号,用于跳转
<为输入重定向,后面为输入文件名
>为输出重定向,后面为输出文件名

fc为比较2个文件是否一致
如果不一致,errorlevel为1

pause为暂停命令,用于观察结果

 


 

Part 3 关于makedata的rand()

记得随机化种子srand(time(0))

rand()返回一随机数值的范围在0至RAND_MAX 间。

RAND_MAX的值在devcpp中为32767

rand()的内部实现是用线性同余法做的,它不是真的随机数,因其周期特别长,故在一定的范围里可看成是随机的。
rand()返回一随机数值的范围在0至RAND_MAX 间。
RAND_MAX的范围最少是在32767之间(int)。
0~RAND_MAX每个数字被选中的机率是相同的。                      
用户未设定随机数种子时,系统默认的随机数种子为1。
rand()产生的是伪随机数字,每次执行时是相同的;若要不同,用函数srand()初始化它。



产生一定范围随机数的通用表示公式:

      要取得[a,b)的随机整数,使用(rand() % (b-a))+ a (结果值含a不含b)。
      要取得[a,b]的随机整数,使用(rand() % (b-a+1))+ a (结果值含a和b)。
      要取得(a,b]的随机整数,使用(rand() % (b-a))+ a + 1 (结果值不含a含b)。

      (总的来说,通用公式:a + rand() % n ;其中的a是起始值,n是整数的范围)

      要取得a到b之间的随机整数,另一种表示:a + (int)b * rand() / (RAND_MAX + 1)。

      要取得0~1之间的浮点数,可以使用rand() / double(RAND_MAX)。

 


 

Part 4 附:MZOJ #81 Makedata

#include<bits/stdc++.h>
using namespace std;

int main()

    srand(time(NULL));
    int n=rand()%100+100;//生成[100,200)内的随机数
    int k=rand()%(n*(n-1)/2)+1;
    printf("%d %d\n",n,k);
    for (int i=1;i<=n;i++)
    
        int x=rand()%100+1;//生成[1,100)内的随机数 
        printf("%d ",x);
    
    return 0;

 

以上是关于快速对拍流程的主要内容,如果未能解决你的问题,请参考以下文章

OI 助手 | 简洁快速的 OI 工具箱 (原 竞赛目录生成)

OI已学知识点总结

Swift快速入门流程控制

java快速开发框架工作流程引擎比较

SpringMVC -- SpringMVC介绍快速入门快速入门流程

几款java工作流程引擎快速开发平台比较