先上代码
#include<bits/stdc++.h>
using namespace std;
int x,y,xi[505],yi[505],n,m,c,b,a[505][505],vis[505][505],f[505][505];
struct node{
int x,y;
int s;
}e,t;
int dx[]={1,-1,0,0};
int dy[]={0,0,1,-1};
queue<node>q;
int bfs(node s)
{
q.push(s);
while(!q.empty()) {
e = q.front();
q.pop();
for (int i = 0; i < 4; i++) {
t.x=e.x+dx[i],t.y=e.y+dy[i];
if(vis[t.x][t.y]||t.x<1||t.y>m||t.x>n||t.y<1)continue;
if(a[t.x][t.y]==1)
return e.s+1;
t.s=e.s+1;
vis[t.x][t.y]=1;
q.push(t);
}
}
}
int main()
{
cin>>n>>m>>c>>b;
for(int i=1;i<=c;i++)
cin>>x>>y,a[x][y]=1;
for(int i=1;i<=b;i++) {
cin >> xi[i] >> yi[i];
if (a[xi[i]][yi[i]] == 1) a[xi[i]][yi[i]] = 2, f[xi[i]][yi[i]] = -1;
else a[xi[i]][yi[i]] = 2;
}
if(b>=500)
{
for(int i=1;i<=c;i++)
cout<<0<<endl;
return 0;
}
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
if(a[i][j]==2&&f[i][j]!=-1) {
e.x = i, e.y = j, e.s = 0, memset(vis, 0, sizeof(vis));
while(!q.empty()) q.pop();
f[i][j] = bfs(e);
}
for(int i=1;i<=b;i++)
if(f[xi[i]][yi[i]]==-1)
cout<<0<<endl;
else
cout<<f[xi[i]][yi[i]]<<endl;
}
从领主bfs第一个搜出来的感染源的时间不就是最优解,当搜到第一个感染源时,停止搜索直接返回时间,为什么有的数据却不对