记录编号 75133 评测结果 AAAAAAAAA
题目名称 [USACO 2.4]两只塔姆沃斯牛 最终得分 100
用户昵称 Gravatardigital-T 是否通过 通过
代码语言 C++ 运行时间 0.004 s
提交时间 2013-10-27 11:14:25 内存使用 0.81 MiB
显示代码纯文本
#include<fstream>
#include<cstring>
#include<string>
using namespace std;
ifstream fi("ttwo.in");
ofstream fo("ttwo.out");
const int N=10;
const int dx[5]={0,-1,0,1,0},dy[5]={0,0,1,0,-1};//1->北 2->东 3->南 4->西
char Map[12][12];
bool boo[12][12][5][12][12][5];
int Fx,Fy,Fd,Cx,Cy,Cd;// x,y坐标 d(direction)方位
void Move(int &x,int &y,int &d)
{
	if(Map[x+dx[d]][y+dy[d]]=='.')
		x+=dx[d],y+=dy[d];
	else
		d=(d%4)+1;
}
int main()
{
	int i,j;
	for(i=0;i<=N+1;i++)Map[0][i]=Map[i][0]=Map[i][N+1]=Map[N+1][i]='*';
	for(i=1;i<=N;i++)
		for(j=1;j<=N;j++)
		{
			fi>>Map[i][j];
			if(Map[i][j]=='F')
				Map[i][j]='.',Fx=i,Fy=j,Fd=1;
			if(Map[i][j]=='C')
				Map[i][j]='.',Cx=i,Cy=j,Cd=1;
		}
	/*for(i=0;i<=N+1;i++)
	{
		for(j=0;j<=N+1;j++)
			fo<<Map[i][j]<<' ';
		fo<<endl;
	}*/
	memset(boo,true,sizeof(boo));
	int step=0;
	if(Fx==Cx&&Fy==Cy){fo<<step<<endl;return 0;}
	while(boo[Fx][Fy][Fd][Cx][Cy][Cd])
	{
		step++;
		boo[Fx][Fy][Fd][Cx][Cy][Cd]=false;
		Move(Fx,Fy,Fd);Move(Cx,Cy,Cd);
		//fo<<Fx<<' '<<Fy<<' '<<Fd<<"   "<<Cx<<' '<<Cy<<' '<<Cd<<endl;
		if(Fx==Cx&&Fy==Cy){fo<<step<<endl;return 0;}
	}
	//fo<<step<<endl;
	fo<<0<<endl;
	return 0;
}