蒟蒻的疑惑
查看原帖
蒟蒻的疑惑
418900
像晚风楼主2021/7/31 10:19

先上代码

#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第一个搜出来的感染源的时间不就是最优解,当搜到第一个感染源时,停止搜索直接返回时间,为什么有的数据却不对

2021/7/31 10:19
加载中...