Cow Navigation(USACO)
题目大意:
给定一个N*N的矩阵,并告诉你每一个格子能否经过,要求你求出(n,1)到(1,n)的最短路径的操作数。
其中操作有2种,第一种是沿着目前的方向走一格,第二种是向左或向右转90°
由于题目设置,一开始我们并不知道起点的方向,所以也可以理解为要我们求出朝向不同但位置相同的2个点的最短路径的方案数,但是注意,此时2个点的操作必须同时进行,比如要前进必须同时前进。
如果某一个点走到了边界外或者走到了不能经过的格子,那么他会返回并且不进行任何操作
如果一个点走到了终点那么接下来的指令它都不会执行
————————————————我是分割线————————————————
这道题目,很显然就是求最短路,然后我们自然会想到spfa
但是这个题目坑就坑在dis数组,由于我们有2个点,而且每个点都有方向,所以是6维的
dis[x1][y1][x2][y2][d1][d2]表示两个点分别从起点走到(x1,y1)方向为d1;走到(x2,y2)方向为d2
然后我们只要初始化后直接SPFA即可
记得check一下有没有超边界。
至于注意事项吗,就是别打挂了。。。暴力调了半小时。。。。。
#include<cstdio>
#include<queue>
#define min(a,b) ((a)<(b)?(a):(b))
#define inf 0x3f3f3f3f
#define MN 21
using namespace std;
int m[MN][MN],dis[MN][MN][MN][MN][][];
int h[]={,-,,,},l[]={,,,,-};
int nowx1,nowx2,nowy1,nowy2,sum1,sum2,td1,td2,ans,n;
bool c[MN][MN][MN][MN][][];
char ch;
struct gather{
int x1,y1,x2,y2,d1,d2;
gather(int x1,int y1,int x2,int y2,int d1,int d2):
x1(x1),y1(y1),x2(x2),y2(y2),d1(d1),d2(d2){}
gather () {}
};
queue<gather>q;
bool check(int x,int y){
if((x<)||(x>n)||(y<)||(y>n))return false;
return true;
}
void spfa()
{
q.push(gather(n,,n,,,));
c[n][][n][][][]=true;
while(!q.empty()){
gather p=q.front();
q.pop();
nowx1=p.x1+h[p.d1];nowx2=p.x2+h[p.d2];
nowy1=p.y1+l[p.d1];nowy2=p.y2+l[p.d2];
if((!check(nowx1,nowy1))||(!m[nowx1][nowy1]))nowx1=p.x1,nowy1=p.y1;
if((!check(nowx2,nowy2))||(!m[nowx2][nowy2]))nowx2=p.x2,nowy2=p.y2;
if(p.x1==&&p.y1==n)nowx1=,nowy1=n;
if(p.x2==&&p.y2==n)nowx2=,nowy2=n;
sum1=dis[nowx1][nowy1][nowx2][nowy2][p.d1][p.d2];
sum2=dis[p.x1][p.y1][p.x2][p.y2][p.d1][p.d2];
if(sum1>sum2+)
{
dis[nowx1][nowy1][nowx2][nowy2][p.d1][p.d2]=sum2+;
if(!c[nowx1][nowy1][nowx2][nowy2][p.d1][p.d2])
q.push(gather(nowx1,nowy1,nowx2,nowy2,p.d1,p.d2));
c[nowx1][nowy1][nowx2][nowy2][p.d1][p.d2]=;
}
td1=(p.d1==)?:p.d1-;td2=(p.d2-==)?:p.d2-;
sum1=dis[p.x1][p.y1][p.x2][p.y2][td1][td2];
if(sum1>sum2+)
{
dis[p.x1][p.y1][p.x2][p.y2][td1][td2]=sum2+;
if(!c[p.x1][p.y1][p.x2][p.y2][td1][td2])
q.push(gather(p.x1,p.y1,p.x2,p.y2,td1,td2));
c[p.x1][p.y1][p.x2][p.y2][td1][td2]=;
}
td1=p.d1==?:p.d1+;td2=p.d2==?:p.d2+;
sum1=dis[p.x1][p.y1][p.x2][p.y2][td1][td2];
if(sum1>sum2+)
{
dis[p.x1][p.y1][p.x2][p.y2][td1][td2]=sum2+;
if(!c[p.x1][p.y1][p.x2][p.y2][td1][td2])
q.push(gather(p.x1,p.y1,p.x2,p.y2,td1,td2));
c[p.x1][p.y1][p.x2][p.y2][td1][td2]=;
}
c[p.x1][p.y1][p.x2][p.y2][p.d1][p.d2]=false;
}
} int main(){
freopen("GP3.in","r",stdin);
freopen("GP3.out","w",stdout);
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%c",&ch);
for(int j=;j<=n;j++)
{
scanf("%c",&ch);
if(ch=='E')m[i][j]=true;
}
}
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
for(int k=;k<=n;k++)
for(int l=;l<=n;l++)
for(int dd1=;dd1<=;dd1++)
for(int dd2=;dd2<=;dd2++)
dis[i][j][k][l][dd1][dd2]=inf;
dis[n][][n][][][]=;
ans=inf;
spfa();
for(int i=;i<=;i++)
for(int j=;j<=;j++)
ans=min(ans,dis[][n][][n][i][j]);
printf("%d\n",ans);
fclose(stdin);
fclose(stdout);
}
Cow Navigation(USACO)的更多相关文章
- Secret Cow code(USACO)
题目描述:zxyer为了防止他的标程被别人抄走,他在计算机中的rar文件上设置了一个密码,其中每一个密码都有一个初始字符串,字符串由大写字母组成,且长度不超过30位,每一个密码还有一个询问,询问为一个 ...
- 考前停课集训 Day2 非
因为太长了 所以一天一天分开发 Day2 昨天晚上没开黑车 没脱衣服就睡了 可能是我难受了…… 新的一天. 早上好. 我没去晨跑,早上先和团长集合了,没看见rkbudlo来 于是就先吃饭了 去机房的时 ...
- 牛客假日团队赛1 D.Promotion Counting
链接: https://ac.nowcoder.com/acm/contest/918/D 题意: Bessie the cow is helping Farmer John run the USA ...
- USACO 2.3 Cow Pedigrees
Cow Pedigrees Silviu Ganceanu -- 2003 Farmer John is considering purchasing a new herd of cows. In t ...
- 3298: [USACO 2011Open]cow checkers
3298: [USACO 2011Open]cow checkers Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 65 Solved: 26[Su ...
- USACO 6.1 Cow XOR
Cow XORAdrian Vladu -- 2005 Farmer John is stuck with another problem while feeding his cows. All of ...
- BZOJ3298: [USACO 2011Open]cow checkers(佐威夫博弈)
3298: [USACO 2011Open]cow checkers Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 195 Solved: 96[S ...
- bzoj 3298: [USACO 2011Open]cow checkers -- 数学
3298: [USACO 2011Open]cow checkers Time Limit: 10 Sec Memory Limit: 128 MB Description 一天,Besssie准备 ...
- USACO 2012 Feb Cow Coupons
2590: [Usaco2012 Feb]Cow Coupons Time Limit: 10 Sec Memory Limit: 128 MB Submit: 349 Solved: 181 [Su ...
随机推荐
- SAP(ABAP):STOP,EXIT,CHECK,RETURN,REJECT,CONTINUE
Stop 命令使用该命令的程序位置INITIALIZATION, AT SELECTION-SCREEN, START-OF-SELECTION和GET 事件中处理说明1. 当在INITIALIZAT ...
- selenium+PhantomJS 抓取淘宝搜索商品
最近项目有些需求,抓取淘宝的搜索商品,抓取的品类还多.直接用selenium+PhantomJS 抓取淘宝搜索商品,快速完成. #-*- coding:utf-8 -*-__author__ =''i ...
- TouTiao开源项目 分析笔记8 图解分析数据加载方式
1.整体构架 1.1.以一个段子页面为例,列出用到的主要的类,以图片的方式展示. 1.2.基础类 这里最基础的接口有: IBaseView<T>==>定义了5个方法. 然后最基础 ...
- 《Cracking the Coding Interview》——第1章:数组和字符串——题目6
2014-03-18 01:45 题目:给定一个NxN的矩阵,就地旋转90度.(没有样例又不说方向的话,随便往哪儿转.) 解法:如果N为奇数,除了中心点以外四等分.如果N为偶数,四等分.按照A-> ...
- 【Decision Tree】林轩田机器学习技法
首先沿着上节课的AdaBoost-Stump的思路,介绍了Decision Tree的路数: AdaBoost和Decision Tree都是对弱分类器的组合: 1)AdaBoost是分类的时候,让所 ...
- asp.net 身份验证-Form 身份验证
一. .net身份验证简介 1.身份验证就是检测用户是否登录及所访问的资源是否有权限.当我们在访问一个受保护网络资源时,往往需要输入用户名.密码信息,或通过其他证书.第三方身份验证等方式.验证(Aut ...
- flask利用session身份伪造
想研究很久了,这次终于初步了解了flask session伪造(得知道密钥). python2和python3 session解密不一样,而且不都是base64,脚本https://github.co ...
- Kotlin中功能操作与集合(KAD 11)
作者:Antonio Leiva 时间:Feb 2, 2017 原文链接:https://antonioleiva.com/functional-operations-collections-kotl ...
- Microsxxxxxxx-面试总结
策略题 There are four kinds of cards, respectively, 1,2, 3,4 numbers. There are seven cards for each ty ...
- 孤荷凌寒自学python第十天序列之字符串的常用方法
孤荷凌寒自学python第十天序列之字符串的常用方法 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) Python的字符串操作方法非常丰富,原生支持字符串的多种操作: 1 查找子字符串 str ...