题目链接
只能过86.67%,不知道问题出在哪了。
#include <bits/stdc++.h>
using namespace std;
#define rep(i,a,n) for(register int i=a;i<=n;++i)
struct p{
int x,y,s;
p(){}
p(int x,int y,int s):x(x),y(y),s(s){}
};
string a[52];
bool b[52][52];
p st,ed;
int xx[8]={1,0,-1,0,1,1,-1,-1};
int yy[8]={0,1,0,-1,1,-1,1,-1};
int n,m;
void bfs(){
queue<p>q;
q.push(st);
b[st.x][st.y]=false;
while(!q.empty()){
p p1=q.front();
q.pop();
if(p1.x==ed.x&&p1.y==ed.y){
cout<<p1.s<<endl;
return;
}
rep(i,0,3){
int tx=p1.x+xx[i],ty=p1.y+yy[i];
if(tx>0&&tx<=n&&ty>0&&ty<=m&&a[tx][ty]=='.'&&b[tx][ty]){
q.push(p(tx,ty,p1.s+1));
b[tx][ty]=false;
}
}
}
puts("Impossible");
}
int main(){
std::ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
cin>>n>>m;
register string x;
a[0]=a[n+1]=" ";
st.x=ed.x=st.y=ed.y=-1;
rep(i,0,n+1)rep(j,0,m+1)b[i][j]=true;
rep(i,0,m){a[0]+=" ";a[n+1]=a[0];}
rep(i,1,n){cin>>x;a[i]=" "+x+" ";}
rep(i,1,n)rep(j,1,m){
if(a[i][j]=='*'){
rep(k,0,7)a[i+xx[k]][j+yy[k]]='#';
}
}
rep(i,1,n)rep(j,1,m){
if(a[i][j]=='S'){
st.x=i;st.y=j;st.s=0;
}
if(a[i][j]=='E'){
ed.x=i;ed.y=j;
a[i][j]='.';
}
}
if(st.x==-1||ed.x==-1)puts("Impossible");
else{
bfs();
}
return 0;
}