Codeforces 1201E2. Knightmare (hard)
看到棋盘先黑白染色冷静一下
然后分析发现,如果初始时两只马在同色的格子,那么一定是后手吃先手
反之一定是先手吃后手
所以分类讨论一下,如果初始在同色的格子,并且后手到达终点的步数更少,那么后手一定赢
并且如果后手威胁到先手终点时的步数比先手到终点的步数少,那么后手下一步直接到先手终点,此时先手为了不被吃最多只能跳到离终点三步的位置(这个自己画一下图就很容易理解了),然后后手再花三步跳到自己终点即可,先手一定是赶不上的
否则,后手就没法阻止先手了
(先手总是有路可以用最短步数到达终点,后手如果可以把先手的最短路径都封锁那么此时后手到达自己终点的步数一定比较小)
总之,画图分类讨论一波
如果是不在同色格子就按先手能否赢讨论即可,都差不多,只是因为先手的原因,步数相等时先手比较快
具体实现看代码吧,代码参考:rui-de
$auto$ 大法好!(请使用 $C++14$ )
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
using namespace std;
typedef long long ll;
const int N=,xx[]={,,,,-,-,-,-},yy[]={,,-,-,-,-,,},INF=1e9;
int n,m,xa,ya,xb,yb;
int d1[N][N],d2[N][N];
struct poi {
int x,y;
poi (int _x=,int _y=) { x=_x,y=_y; }
};
queue <poi> Q;
void BFS(int sx,int sy,auto &mp)
{
Q.push(poi(sx,sy)); mp[sx][sy]=;
while(!Q.empty())
{
poi u=Q.front(); Q.pop();
for(int k=;k<;k++)
{
int tx=u.x+xx[k],ty=u.y+yy[k];
if(tx<||tx>n||ty<||ty>m||mp[tx][ty]<INF) continue;
mp[tx][ty]=mp[u.x][u.y]+; Q.push(poi(tx,ty));
}
}
}
void dfs(int sx,int sy,auto &mp)
{
for(int k=;k<;k++)
{
int tx=sx+xx[k],ty=sy+yy[k];
if(tx<||tx>n||ty<||ty>m||mp[tx][ty]>=mp[sx][sy]) continue;
cout<<tx<<" "<<ty<<endl; dfs(tx,ty,mp); break;
}
}
int main()
{
memset(d1,0x3f,sizeof(d1)); memset(d2,0x3f,sizeof(d2));
cin>>n>>m; cin>>xa>>ya>>xb>>yb;
BFS(n/,m/,d1); BFS(n/+,m/,d2);
int wht=d1[xa][ya],blk=d2[xb][yb];
int w_b=d2[xa][ya],b_w=d1[xb][yb];
if( ((xa+ya)&) == ((xb+yb)&) )
{
if(blk<wht) { printf("BLACK\n"); dfs(xb,yb,d2); return ; }
if( b_w-<wht )
{
printf("BLACK\n");
dfs(xb,yb,d1); dfs(n/,m/,d2);
return ;
}
printf("WHITE\n"); dfs(xa,ya,d1);
return ;
}
if(wht<=blk) { printf("WHITE\n"); dfs(xa,ya,d1); return ; }
if(w_b-<=blk)
{
printf("WHITE\n");
dfs(xa,ya,d2); dfs(n/+,m/,d1);
return ;
}
printf("BLACK\n"); dfs(xb,yb,d2);
return ;
}
Codeforces 1201E2. Knightmare (hard)的更多相关文章
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
- CodeForces - 274B Zero Tree
http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...
- CodeForces - 261B Maxim and Restaurant
http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...
- CodeForces - 696B Puzzles
http://codeforces.com/problemset/problem/696/B 题目大意: 这是一颗有n个点的树,你从根开始游走,每当你第一次到达一个点时,把这个点的权记为(你已经到过不 ...
- CodeForces - 148D Bag of mice
http://codeforces.com/problemset/problem/148/D 题目大意: 原来袋子里有w只白鼠和b只黑鼠 龙和王妃轮流从袋子里抓老鼠.谁先抓到白色老鼠谁就赢. 王妃每次 ...
随机推荐
- tsconfig.json配置说明
配置 tsconfig.json tsconfig.json 所包含的属性并不多,只有 7 个,ms 官方也给出了它的定义文件.但看起来并不怎么舒服,这里就翻译整理一下.(若有误,还请指出) file ...
- 关于Array.reduce的理解与拓展
2018年1月6日 首先我要感谢我的同事徒步上山看日出在我第一份实习的时候对我的指导,现在我也开始跟他一样开始养成写博客的习惯 现在开始讨论我遇到的第一个问题,这是我在看javascript高级程序设 ...
- The remote system refused the connection.
使用SecureCRT连接Ubuntu时,报错: The remote system refused the connection. 说明Ubuntu上没有安装openssh-server,使用命令: ...
- leetcode-hard-array-454 4sum II-NO
mycode 过不了...我也不知道为什么... class Solution(object): def fourSumCount(self, A, B, C, D): ""& ...
- leetcode131分割回文串
class Solution { public: vector<vector<string>> ans; bool isok(string s){ ; ; while(i< ...
- [redis]redis实现分页的方法
每个主题下的用户的评论组装好写入Redis中,每个主题会有一个topicId,每一条评论会和topicId关联起来,大致的数据模型如下:{ topicId: 'xxxxxxxx', comments: ...
- go 基础 处理异常
package main import "fmt" func main() { dosomething() } func dosomething(){ defer func() { ...
- 数据库高级数据库学习--上机练习7(Transact-SQL 函数定义和调用)
上机练习7 在Transact SQL中,有一类特殊的自定义函数,其返回值为一张表,该类自定义函数被称作内嵌(联)表值函数,其基本语句格式如下: CREATE FUNCTION函数名称[( {@参数名 ...
- Linux :linux磁盘分区(普通分区2T以内),安装免安装版mysql(tar.gz)
1.磁盘分区: 1 以root身份登录 查看磁盘信息(自行选择需要使用的磁盘,此处只需要了解信息) fdisk –l 创建新硬盘 fdisk /dev/vdb (决定使用哪个磁盘) 输入n回车,再输入 ...
- 人性化的Requests模块(响应与编码、header处理、cookie处理、重定向与历史记录、代理设置)
Requests库是第三方模块,需要额外进行安装.Requests是一个开源库 pip install requests 去GitHub下载回来,进入解压文件,运行setup.py 比urllib2实 ...