社区讨论

暴力枚举TLE求调

B4263[GESP202503 四级] 荒地开垦参与者 3已保存回复 6

讨论操作

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

当前回复
6 条
当前快照
1 份
快照标识符
@mjy743gl
此快照首次捕获于
2026/01/03 19:04
2 个月前
此快照最后确认于
2026/01/03 20:32
2 个月前
查看原帖
CPP
#include <bits/stdc++.h>
using namespace std;

char AC[7891][7891];
int n=0,m=0,ma=0;
vector<int> x,y;
bool op(int i,int j){
    if(AC[i][j]=='.'&&AC[i+1][j]=='.'&&AC[i-1][j]=='.'&&AC[i][j+1]=='.'&&AC[i][j-1]=='.') return 1;
    else return 0;
}
int main(){
    int c=0;
    cin >> n >> m;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            cin >> AC[i][j];
            if(AC[i][j]=='#'){
                x.push_back(i);
                y.push_back(j);
            }
        }
    }
    for(int index=0;index<x.size();index++){
        int index_i=x[index];
        int index_j=y[index];
        AC[index_i][index_j]='.';
        int c=0;
        for(int i=1;i<n-1;i++){
            for(int j=1;j<m-1;j++){
                if(op(i,j)) c++;
            }
        }
        ma=max(ma,c);
        AC[index_i][index_j]='#';
    }
    cout << ma << endl;
    return 0;
}

回复

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

正在加载回复...