社区讨论

本地能过样例但洛谷TLE

P2960[USACO09OCT] Invasion of the Milkweed G参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@mhj38or5
此快照首次捕获于
2025/11/03 20:00
4 个月前
此快照最后确认于
2025/11/03 20:00
4 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int x,y,ans2,ans,f[8][2]={{0,1},{1,1},{-1,0},{0,-1},{-1,-1},{-1,1},{1,-1},{1,0}};
char g[999][999];
struct point{
    int x,y;
};
queue<point> q;

int bfs(){
    while(ans){
        ans2++;
    int len=q.size();
    for(int i=0;i<len;i++){
        int qx=q.front().x;
        int qy=q.front().y;
        q.pop();
        for(int j=0;j<8;j++){
            if(g[qx+f[j][0]][qy+f[j][1]]=='.'){
                g[qx+f[j][0]][qy+f[j][1]]='M';
                q.push({qx+f[j][0],qy+f[j][1]});
                ans--;
                
            }
        }
    }
    }
}
int main(){
    int mx,my;
    cin>>x>>y>>mx>>my;
    for(int i=y;i>0;i--){
        for(int j=1;j<=x;j++){
            cin>>g[j][i];
            if(g[j][i]=='.')ans++;
        }
    }
    q.push({mx,my});
    bfs();
    cout<<ans2;
}
如题,求助

回复

2 条回复,欢迎继续交流。

正在加载回复...