COWRUN
USACO COWRUN 随机化搜索+双重递归调用
题面描述:给出8*N(<=14)组牌,每次按顺序选择8张,FJ可以选择前4张或者后4张,COW从FJ选出的牌中选择前两张或者后两张,然后COW会在环上走\(R \times A+B\),R为已经走的距离,A,B分别为选出的第一张和第二张牌,COW会在长度为M的换上走,要求最终cow,离起点的距离小于等于K,题目给出COW的决策,你要确定FJ的决策,注意由于FJ在COW 之前决策,也就说FJ所选出的决策一定要满足,无论之后COW如何选择,COW都能满足条件,求字典序最小
题目非常巧妙:N很小我们 可以搜索,如何去判断FJ的决策合法:枚举到下一层奶牛选择的两种可能,他们必须都合法,如何验证他们的合法性,分别进入下一层搜索树,只要有一个FJ的决策合法即可
这样做只有80分:数据可能会K你的决策 比如有很多的T
code
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
int n;
long long m,k;
int aa[20][10];
char s[20];
inline int cal(int pos,long long now,int a,int b){
int temp=4*a+2*b+1;
return (now*(aa[pos][temp]+1)%m+aa[pos][temp+1])%m;
}
inline bool dfs(int pos,long long now,int a);
inline bool efs(int pos,long long now){
if(pos>n)return now<=k || now>=m-k;
return dfs(pos,now,1)||dfs(pos,now,0);
}
inline bool dfs(int pos,long long now,int a){
return efs(pos+1,cal(pos,now,a,1))&&efs(pos+1,cal(pos,now,a,0));
}
int main(){
cin>>n>>m>>k;
scanf("%s",s+1);
for(int i=1;i<=n;++i)
for(int j=1;j<=8;++j)cin>>aa[i][j];
long long now=0;
for(int i=1;i<=n;++i){
if(dfs(i,now,1)){
cout<<"B";
now=cal(i,now,1,s[i]=='B');
}
else {
cout<<"T";
now=cal(i,now,0,s[i]=='B');
}
}
return 0;
}
/*
2 2 0
TT
1 0 0 0 0 0 0 1
0 1 1 1 0 0 1 0
*/
类似TREAP的思想:随机化COW的选择判断答案的合法性不会被数据HACK
code:
#include<cstdio>
#include<cstring>
#include<iostream>
#include<cstdlib>
using namespace std;
int n;
long long m,k;
int aa[20][10];
char s[20];
inline int cal(int pos,long long now,int a,int b){
int temp=4*a+2*b+1;
return (now*(aa[pos][temp]+1)%m+aa[pos][temp+1])%m;
}//第pos次拿牌,当前位置在now,fj选了a,cow选了b后的位置
inline bool dfs(int pos,long long now,int a);
inline bool efs(int pos,long long now){
if(pos>n)return now<=k || now>=m-k;
int x=rand()&1;
return dfs(pos,now,x)||dfs(pos,now,!x);//个
}//第pos次拿牌,当前位置在now,是否可行,验证就是FJ强制选或强制不选
inline bool dfs(int pos,long long now,int a){
int x=rand()&1;
return efs(pos+1,cal(pos,now,a,x))&&efs(pos+1,cal(pos,now,a,!x));
}//第pos次拿牌,当前位置在now,fj选择a是否可行,验证只需后一个奶牛是否可以随便选
int main(){
cin>>n>>m>>k;
scanf("%s",s+1);
for(int i=1;i<=n;++i)
for(int j=1;j<=8;++j)cin>>aa[i][j];
long long now=0;
for(int i=1;i<=n;++i){
if(dfs(i,now,1)){
cout<<"B";
now=cal(i,now,1,s[i]=='B');
}
else {
cout<<"T";
now=cal(i,now,0,s[i]=='B');
}
}
return 0;
}
/*
2 2 0
TT
1 0 0 0 0 0 0 1
0 1 1 1 0 0 1 0
*/
COWRUN的更多相关文章
- USACO翻译:USACO 2012 JAN三题(2)
USACO 2012 JAN(题目二) 一.题目概览 中文题目名称 叠干草 分干草 奶牛联盟 英文题目名称 stacking baleshare cowrun 可执行文件名 stacking bale ...
- COGS 146. [USACO Jan08] 贝茜的晨练计划
★☆ 输入文件:cowrun.in 输出文件:cowrun.out 简单对比时间限制:1 s 内存限制:32 MB 奶牛们打算通过锻炼来培养自己的运动细胞,作为其中的一员,贝茜选择的运 ...
- noip2018 pre——Dp
Dp专题 1011: KC的瓷器 (porcelain) 题目描述 KC来到了一个盛产瓷器的国度.他来到了一位商人的店铺.在这个店铺中,KC看到了一个有n(1<=n<=100)排的柜子,每 ...
- bzoj2581 [USACO 2012 Jan Gold] Cow Run【And-Or Tree】
传送门1:http://www.usaco.org/index.php?page=viewproblem2&cpid=110 传送门2:http://www.lydsy.com/JudgeOn ...
- 2016.8.15上午纪中初中部NOIP普及组比赛
2016.8.15上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1333 这次比赛不怎么好,因为这套题目我并不是很擅长. 可同学们 ...
随机推荐
- 洛谷 P2027 bf
P2027 bf 题目描述 bf是一种编程语言,全称为BrainFuck,因为题目名称不能太露骨,所以就简写成bf了. 这种语言的运行机制十分简单,只有一个大小为30000的有符号8位整数(范围[-1 ...
- 阿里云CentOS系统配置iptables防火墙
虽说阿里云推出了云盾服务,但是自己再加一层防火墙总归是更安全些,下面是我在阿里云vps上配置防火墙的过程,目前只配置INPUT.OUTPUT和FORWORD都是ACCEPT的规则 一.检查iptabl ...
- 【Android进阶篇】Fragment的两种载入方式
一.概述 Fragment(碎片,片段)是在Android 3.0后才引入的,基本的目的是为了实如今大屏幕设备上的更加动态更加灵活的UI设计. 这是由于平板电脑的屏幕比手机大得多,所以屏幕上能够放很多 ...
- opecv2 MeanShift 使用均值漂移算法查找物体
#if !defined OFINDER #define OFINDER #include <opencv2\core\core.hpp> #include <opencv2\img ...
- Find or Query Data with the mongo Shell
https://docs.mongodb.com/getting-started/shell/query/ Overview You can use the find() method to issu ...
- nyoj--1170--最大的数(数学技巧)
最大的数 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 小明和小红在打赌说自己数学学的好,于是小花就给他们出题了,考考他们谁NB,题目是这样的给你N个 ...
- links[v1]
justep core java Spring Boot ui5 template spring Cross-origin resource sharing 统一异常处理 数据库连接池的选择 Drui ...
- iview中键盘上下左右事件的方法
document.addEventListener('keydown', function(e){ var keyCode = e.keyCode; // Esc slide-up ) { e.pre ...
- 分享一个简单好用的ipv6正则表达式
网上找了好几个,都不太好使.比较严谨的又运行缓慢,而且文本中多处含ipv6的时候,又提取不出全部的ipv6. 故分享一个不太严谨效率又高的ipv6正则表达式: ([a-f0-9]{1,4}(:[a-f ...
- iOS下调用元素的focus方法,input元素不聚焦,键盘不弹起的问题
页面元素 <input type="text" ref="elInput"/> <div style="margin-top:20p ...