简单的对拍

  在算法竞赛中,我们常用对拍来初步检验程序。

  网上也有其它的关于对拍的教程,但是任性的我还是要自己写一篇教程。 

   666

 

  首先,我们要知道我们是用一个叫做” 批处理文件(.bat)“的东西来处理这个问题。点击初步了解bat

     不过不必深究这个,因为我们只用其中一小部分。

  那么,我的基本思路是:

              ①先得到测试数据及答案(可用符合题意的随机数程序);

              ②打开标准程序(或你的暴力程序)和你的程序并生成答案;

              ③比较文件,一致则循环比较,否则输出文件不同点;

  当然,你可以添加一些功能,如:综合时间和正确率给程序评分等(我就懒得写了)。

  先用一个例子来示范一下

    就用2016年noip第一天的第一题, 点击查看题目

    接着写我们的bat文件了(建议比赛开场前时写)

    实所谓的批处理文件,就是把DOS命令先写下来。所以,就用记事本写就行,然后后缀改成.bat。点击了解怎么改后缀

  我写的bat:

@echo off    ::关回显,不必深究
:sign        ::标识符,与C语言的用法大致一样
rand     ::一个用于生成输入文件的随机数程序 biggodsans ::执行大神与我的程序 myans fc biggodsans.out myans.out ::比较文件
if errorlevel 0 goto sign ::如果文件一样的话就跳转回sign处继续处理,否则将在屏幕显示错误信息(该行一定要连一起写)

 其实重点在第六行,这个bat就是用来检验你的答案是否和标准答案完全一致(如有格式要求的题目)。

  所以,只写一行也行。

  用两个测试数据说明问题。点击获取测试数据

  修改一下文件名,简单测试文件比较

@echo off
fc biggodsans.out myans.out
pause          ::可能会一闪而过,起暂停屏幕作用

用toy6.in所得结果

用toy16.in得到错误信息

它会显示不同处的上下文(我这里是程序没有输出)

 大概就是这样了

 

 


一个华丽的分割线,以下是我和大神的代码

 

 

 

  我的代码是()

 1 #include<cstdio>
 2 #include<iostream>
 3 #include<string>
 4 using namespace std;
 5 string name[100006];
 6 bool inorout[100006];               //第i个小人的朝向,false表示向内 
 7 int n,m;
 8 int i,j,ai,si;
 9 int nowp=1;
10 int main()
11 {
12     freopen("toy.in","r",stdin);
13     freopen("myans.out","w",stdout);
14     scanf("%d%d",&n,&m);
15      for(i=1;i<=n;++i)
16              { 
17                      scanf("%d",&j);
18                      inorout[i]=(j==0?false:true);          
19                      cin>>name[i];
20                      } 
21                  while(m--)              //就是一个简单的模拟
22                  {                
23                   scanf("%d%d",&ai,&si);
24                   if(inorout[nowp]==(bool)ai)    nowp=nowp-si+n;      //显然朝向和向左右数有关
25                   else                           nowp+=si;
26                   nowp=nowp%n;          //注意:它是个圈!!!       
27              }
28     cout<<name[nowp];   
29     return 0;
30 }
31     

 

我以为我完全正确。然而,我得了90分...

我终于知道题目里的mengbier是谁了      尴尬

比赛后我找到大神的答案

 1 #include<cstdio>    //大神的代码,膜拜ing...
 2 const int N=1e5+5,L=11;
 3 int n,q,i,a[N],x;
 4 char s[N][L];
 5 int read(){
 6     char c=getchar();int k=0;for (;c<48||c>57;c=getchar());
 7     for (;c>47&&c<58;c=getchar()) k=(k<<3)+(k<<1)+c-48;return k;
 8 }
 9 int main(){
10     freopen("toy.in","r",stdin);
11     freopen("biggodsans.out","w",stdout);
12     for (n=read(),q=read(),i=0;i<n;i++){
13         a[i]=read();scanf("%s",s[i]);
14     }
15     for (x=0;q--;){
16         int opt=read()^a[x],k=read();
17         if (opt) x=(x+k)%n;
18         else x=(x-k+n)%n;
19     }
20     printf("%s",s[x]);
21 }

 

转载于:https://www.cnblogs.com/callmebg/p/6347892.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/284761.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI 之 OpenCvSharp 大图找小图(案例版)

要说跟AI扯上啥关系&#xff0c;估计只有库本身了&#xff0c;但是&#xff0c;这个大图搜小图功能还是不错的&#xff0c;有喜欢的可以试试。我主要用的场景是&#xff0c;具体的某个界面为大图&#xff0c;界面的某个图标为小图&#xff0c;或者&#xff0c;整个桌面为大图&a…

SaaS应用的十二要素

简介 如今&#xff0c;软件通常会作为一种服务来交付&#xff0c;它们被称为网络应用程序&#xff0c;或软件即服务&#xff08;SaaS&#xff09;。12-Factor 为构建如下的 SaaS 应用提供了方法论&#xff1a; 使用标准化流程自动配置&#xff0c;从而使新的开发者花费最少的…

对话Linus:Linux 25岁啦

作为芬兰Helsinki大学计算机科学系的学生&#xff0c;Linus Torvalds在1991年编写了Linux操作系统的原始内核。很快&#xff0c;Linux就发展成为了一个全特征的操作系统&#xff0c;并开始运行在智能手机、服务器和各种设备中。在本次通过e-mail进行的访谈中&#xff0c;Torval…

路由器与交换机区别

路由器与交换机区别 近日&#xff0c;在回答知道网友提问的时候&#xff0c;发现很多朋友不知道路由器与交换机的不同&#xff0c;常常问一些看起来有点可笑的问题。比如路由器同时登陆两个账号&#xff0c;所以今天写下这篇经验&#xff0c;科普一下路由器的功能和交换机的功能…

【QGIS入门实战精品教程】1.2:QGIS与ArcGIS的区别和联系

「刘一哥GIS」系列专栏《QGIS入门实战精品教程(配套案例数据)》目录 以下是GISGeography官方给出的两者之间的27点比较(译): 官方网址:https://gisgeography.com/qgis-arcgis-differences/ 1.QGIS容纳更多的数据格式 ArcGIS没有支持所有的数据格式,毫无疑问,QGIS在处…

mysql中的增删改查

显示数据库中有的表格 SHOW TABLES增 新建表格 CREATE TABLE urls( id int, url varchar(100), description varchar(100) ) 插入值 INSERT INTO chflvghu_test.user (user, password) VALUES (小红, qwerty); 插入多条数据 INSERT INTO chflvghu_test.user (user, password) V…

押注.NET 是件好事

作者 | Bryan Costanich译者 | 明知山策划 | 褚杏娟作为一个在.NET 上构建了不止一个流行平台的人&#xff0c;我经常被问到它的相关性&#xff0c;以及它是不是一个值得投入的生态系统。这个问题在旧金山湾区的技术世界里尤为流行&#xff0c;这里的技术潮流就像四季一样变更交…

8-12 canvas专题-阶段练习一(上)

8-12 canvas专题-阶段练习一&#xff08;上&#xff09; 1 <!DOCTYPE html>2 <html lang"zh-cn">3 <head>4 <meta charset"UTF-8">5 <title>8-12 课堂演示</title>6 </head>7 <style type"text…

【QGIS入门实战精品教程】2.2:QGIS软件的下载与安装(Windows)

文章目录 一、QGIS下载二、QGIS安装​一、QGIS下载 QGIS软件官网下载地址:https://www.qgis.org/en/site/ 进入官网之后,点击【Download Now】进入下载页面: 选择对应的版本进行下载: 开始下载:

UVa 10061 How many zero's and how many digits?

方法&#xff1a; factorial mod&#xff0c; logarithm 求trailing zeros&#xff0c;其实就是factorial mod 的应用&#xff0c; 求长度&#xff0c;利用log 函数。需要注意的是&#xff0c;答案为int(log(n!)/log(b)) 1, 比如 a 2, b 2, 长度为2. code: #include <cst…

Linux sudo找不到命令:修改sudo的PATH路径

为什么80%的码农都做不了架构师&#xff1f;>>> sudo有时候会出现找不到命令&#xff0c;而明明PATH路径下包含该命令&#xff0c;让人疑惑。其实出现这种情况的原因&#xff0c;主要是因为当 sudo以管理权限执行命令的时候&#xff0c;linux将PATH环境变量进行了重…

Javscript 实现字符数串比对排序(包含数字及中文数字)

主要代码&#xff1a; /** *description: 比较两个字符串大小 *author: JackieZheng *date: 2020-12-03 19:59:39 */ function compare(a, b) {if (a b) {return 0;} else {let lsta a.toString().replace(/[一二三四五六七八九十百千万亿]/g, ChineseToNumber).split(/(\d…

【QGIS入门实战精品教程】4.2:QGIS矢量数据采集(地图数字化)案例教程

本文基于上一个实验栅格数据地理配准,讲述在QGIS中创建shp格式矢量数据(点、线、面)并进行矢量数据的采集与编辑。 文章目录 一、实验数据及任务二、创建Shapefile图层三、数字化超详细步骤一、实验数据及任务 1. 实验数据:为了保证实验的连贯性,本次实验采用的数据为上一…

快速判断站点是否存活的 3 种编程实现

前言如何知道外部站点是否正在运行&#xff1f;如果使用浏览器&#xff0c;直接访问对应站点即可。那么&#xff0c;使用 C# 以编程方式&#xff0c;如何实现呢&#xff1f;GET 请求首先想到的&#xff0c;就是使用 HttpClient 向该站点发送 HTTP 请求&#xff0c;并检查返回状…

jQuery.ajax实现根据不同的Content-Type做出不同的响应

使用H5ASP.NET General Handler开发项目&#xff0c;使用ajax进行前后端的通讯。有一个场景需求是根据服务器返回的不同数据类型&#xff0c;前端进行不同的响应&#xff0c;这里记录下如何使用$.ajax实现该需求。 $.ajax({‘url‘: ‘GetWatermarkInfo.ashx‘,‘type‘:‘post…

论文的写作要求、流程与写作技巧

论文的写作要求、流程与写作技巧 广义来说&#xff0c;凡属论述科学技术内容的作品&#xff0c;都称作科学著述&#xff0c;如原始论著&#xff08;论文&#xff09;、简报、综合报告、进展报告、文献综述、述评、专著、汇编、教科书和科普读物等。但其中只有原始论著及其简报是…

【数据结构与算法】拓扑排序问题C语言实现

拓扑排序是有向无环图的一种应用,在实际生活中用的很多。 比如GIS专业的课程设计,许多课程需要前置课程要求,也就是说没上过A课程、则不可能直接去学B课程,画个图表就是: 同理,我们教材中的范例:穿衣服的过程也是一个拓扑排序问题,如下表: 有关这个拓扑排序的模型构造…

[转]2020年排名前20的基于SpringBoot搭建的开源项目,帮你快速进行项目搭建!

△Hollis, 一个对Coding有着独特追求的人△ 这是Hollis的第 287 篇原创分享 作者 l Hollis 来源 l Hollis&#xff08;ID&#xff1a;hollischuang&#xff09; SpringBoot一直是开发者比较青睐的一款轻量级框架&#xff0c;他不仅继承了Spring框架原有的优秀特性&#xff0c;而…

操作系统基础知识

操作系统的主要特性: 并发,共享,异步,虚拟性 分类 批处理系统 用户将一批作业提交给操作系统后就不再干预&#xff0c;由操作系统控制它们自动运行 批处理操作系统的特点是&#xff1a;多道和成批处理。分时实时可以通过命令接口和程序接口方式把它的服务和功能提供给用户 程序…

C# 搭建一个基于.NET5的WPF入门项目

概述.NET5 发布已经有一阵子了&#xff0c;今天抽空体验一哈&#xff0c;搭建一个WPF项目实例&#xff0c;看看和传统的.NET Framework有什么区别&#xff01;开发环境&#xff1a;VS2019 WPF框架&#xff1a;Caliburn.Micro 版本4.0.173.NET版本&#xff1a;.NET5.0项目创建步…