介绍
做完一道题目后,当你有一堆的测试数据,却没有用来测评的OJ,就只能一个数据一个数据的测试时,你的心态一定是崩的,所以需要我们自己来编写一个测评程序,批量进行测评,有助于加快测评速度。
代码(judge.cpp
)
其实代码很简单,很通俗易懂,萌新应该都看得懂
#include<cstdlib>
#include<iostream>
#include<string>
#include<cstring>
#include<ctime>
#include<cstdio>
#include<cmath>
#include<windows.h> //这里写了一堆头文件,虽然除了一个以外都可以使用万能头文件,但是拒绝万能头文件从我做起
using namespace std;
int cw(int a){ //一个拆位函数
int ans=0;
while(a>0){
ans++;
a/=10;
}
return ans;
}
int main(){
string name,in=".in",outans,out=".out",exe=".exe",exefile=".exe",infile=".in",outfile=".out",ansfile=".csv"; //现将需要用到的文件后缀名写好,方便后期使用
int g,gn,n,fen,ff=0,flag1=0,flag2=0;
double TT=0.0; //这里的TT记录每个测试点中所用的最大时长,用双精度浮点数提高精度
printf("请输入题目名:");
cin>>name;
printf("请输入测试数据中输出文件的后缀名(ans / out):"); //有些题目的测试数据中的输出文件的后缀名是'.out'但有些是'.ans'
cin>>outans;
outans.insert(0,".");
printf("请输入测试数据末尾数字格式:1.题目名后直接加数字没有0补位 2.题目名后加数字有0补位 (输入编号1/2即可): "); //有些测试数据是题目名直接加数字,比如'name1.in',而有些测试数据是题目名后加数字且有0补位,比如'name001.in'
scanf("%d",&g);
printf("请输入测试数据个数:");
scanf("%d",&n);
int wn=cw(n)
printf("请");
while(g==2){
printf("输入补位后数字总位数:");
scanf("%d",&gn);
if(wn>=gn)
break;
printf("位数过少,至少%d位\n请重新",wn);
}
exefile.insert(0,name);
infile.insert(0,name);
ansfile.insert(0,name);
outfile.insert(0,name);
fen=100/n; //此处记录一个测试数据多少分
FILE* lans=fopen(ansfile.c_str(),"w"); //这里程序还会把测评结果保存到csv表格中
fprintf(lans,"编号,结果,用时(s),得分\n");
string cmd2="del ",cmd4="del ";
for(int i=1;i<=n;i++){
string cmd1="copy ",cmd3="fc ";
cmd1+=name;
cmd3+=outfile;
cmd3+=" ";
cmd3+=name;
switch(g){ //这个switch中是分别加上in和out/ans文件中的数字
case 1:{
if(i<10){
cmd1+=char(i+'0');
cmd3+=char(i+'0');
}
else if(i<100){
cmd1+=char(i/10+'0');
cmd1+=char(i%10+'0');
cmd3+=char(i/10+'0');
cmd3+=char(i%10+'0');
}
else if(i<1000){
cmd1+=char(i/100+'0');
cmd1+=char((i/10)%10+'0');
cmd1+=char(i%10+'0');
cmd3+=char(i/100+'0');
cmd3+=char((i/10)%10+'0');
cmd3+=char(i%10+'0');
}
else if(i<10000){
cmd1+=char(i/1000+'0');
cmd1+=char((i/100)%10+'0');
cmd1+=char((i/10)%10+'0');
cmd1+=char(i%10+'0');
cmd3+=char(i/1000+'0');
cmd3+=char((i/100)%10+'0');
cmd3+=char((i/10)%10+'0');
cmd3+=char(i%10+'0');
}
break;
}
case 2:{
for(int j=gn-1;j>=0;j--){
int gog=pow(10,j);
cmd1+=char((i/gog)%10+'0');
cmd3+=char((i/gog)%10+'0');
}
break;
}
}
cmd1+=in;
cmd1+=" ";
cmd1+=infile;
cmd3+=outans;
fprintf(lans,"%d,",i);
int time1,time2;
double T;
system(cmd1.c_str());
time1=clock();
system(exefile.c_str());
time2=clock();
T=double((double(time2)-double(time1))/1000.0);
TT=T>TT?T:TT;
if(T>1.0) //这里判断次测试点是否超时(默认时间限制1s,可自行修改)
fprintf(lans,"TLE,%.3lf,%d\n",T,0),printf("TLE,%.3lf,%d\n",T,0),flag2=2;
else if(!system(cmd3.c_str())) //如果没有时间超限则判断输出是否正确
fprintf(lans,"AC,%.3lf,%d\n",T,fen),printf("AC,%.3lf,%d\n",T,fen),ff+=fen;
else
fprintf(lans,"WA,%.3lf,%d\n",T,0),printf("WA,%.3lf,%d\n",T,0),flag1=1;
}
cmd2+=infile;
cmd4+=outfile;
system(cmd2.c_str());
system(cmd4.c_str());
fprintf(lans,"总结果,");
if(flag1==0&&flag2==0) //最后输出一行总结果
fprintf(lans,"AC,");
else if(flag1==1&&flag2==0)
fprintf(lans,"WA,");
else if(flag2==2)
fprintf(lans,"TLE,");
fprintf(lans,"%.3lf,%d",TT,ff);
fclose(lans);
return 0;
}
注:C++暂时不支持获取运行内存,所以不能判断内存超限,而且既然可以测评说明编译不会错,所以也不能判断是否编译错误
怎么样,是不是非常的通俗易懂~~(bushi)~~
那我来讲一下使用说明吧!
使用说明
把上面这串代码编译后的文件(judge.exe
)放进在带有测试数据(.in
.out/.ans
)的文件夹,把你写的代码编译好的文件(.exe
)(注意 :你的程序需要用加上freopen
,输入文件名为 题目名+.in
,输出文件名为 题目名+.out
,更多有关内容可自行搜索)也放在那个文件夹里面,然后运行judge.exe
,按照提示输入即可测评。
结尾
如果还有其他疑问可以提在下面的==评论区==,我会一一解答。
如果你觉得这篇文章写的很好,记得 ==关注,点赞,评论,转发==