记录编号 |
75133 |
评测结果 |
AAAAAAAAA |
题目名称 |
[USACO 2.4]两只塔姆沃斯牛 |
最终得分 |
100 |
用户昵称 |
digital-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;
- }