# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
101547 | rainy | Tracks in the Snow (BOI13_tracks) | C++14 | 4 ms | 640 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#include<utility>
#include<queue>
#define INF 32000
using namespace std;
typedef vector<short> vi;
typedef pair<short,short>ii;
short H,W;
char X;
short dx[]={0,1,0,-1},dy[]={1,0,-1,0};
/*
void prvt(vector<vi> vv){
prshortf("---\n");
for(short i=0;i<H;i++){
for(short j=0;j<W;j++){
if(vv[i][j]==-1)prshortf("-");
else prshortf("%hd",vv[i][j]);
}
prshortf("\n");
}
prshortf("---\n");
}
*/
short tis(vector<vi> x, short ani){
queue<ii>q;q.push(ii(0,0));
x[0][0]=-1;
bool vis[H+5][W+5]={false};
vis[0][0]=true;
while(!q.empty()){
int x1=q.front().first,y1=q.front().second;
q.pop();
for(short k=0;k<4;k++){
short nx=x1+dx[k],ny=y1+dy[k];
if(0<=nx&&nx<H&&0<=ny&&ny<W){
if(!vis[nx][ny]){
if(x[nx][ny]==-1||x[nx][ny]==ani){
vis[nx][ny]=true;
x[nx][ny]=-1;
q.push(ii(nx,ny));
}
}
}
}
}
//prvt(x);
if(!vis[H-1][W-1])return INF;
bool isDone=true;bool has1=false,has2=false;
for(short i=0;i<H;i++){
for(short j=0;j<W;j++){
if(x[i][j]==1){
has1=true;isDone=false;
}
if(x[i][j]==2){
has2=true;isDone=false;
}
}
}
if(isDone)return 0;
short ans=INF;
if(has1)ans=tis(x,1);
if(has2)ans=min(tis(x,2),ans);
return 1+ans;
}
int main(){
scanf("%d%d",&H,&W);
vector<vi> gr(H);
for(short i=0;i<H;i++){
vi xyz(W);
for(short j=0;j<W;j++){
xyz[j]=-1;
}
gr[i]=xyz;
}
for(short i=0;i<H;i++){
for(short j=0;j<W;j++){
scanf(" %c",&X);
if(X=='.')gr[i][j]=0;
if(X=='F')gr[i][j]=1;
if(X=='R')gr[i][j]=2;
}
}
/*
for(short i=0;i<H;i++){
for(short j=0;j<W;j++){
prshortf("%d",gr[i][j]);
}
prshortf("\n");
}
*/
printf("%hd\n",1+tis(gr,gr[0][0]));
return 0;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |