社区讨论

80pts???

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

讨论操作

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

当前回复
0 条
当前快照
1 份
快照标识符
@mhj126q4
此快照首次捕获于
2025/11/03 18:59
4 个月前
此快照最后确认于
2025/11/03 18:59
4 个月前
查看原帖
CPP
#include <bits/stdc++.h>

using namespace std;

char mp[1010][1010];
int n, m;

bool check1(int x, int y) {
    return mp[x][y] != '#';
}

bool check2(int x, int y) {
    return check1(x - 1, y) && check1(x, y - 1)
    && check1(x, y + 1) && check1(x + 1, y);
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            cin >> mp[i][j];
        }
    }

    int ans = 0, maxgx = INT_MIN;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            if (check2(i, j) && check1(i, j)) {
                ans++;
            } else if (!check1(i, j)) {
                mp[i][j] = '.';
                int cnt = 0;

                if (check2(i, j)) {
                    cnt++;
                }
                if (i > 1) {
                    if (check2(i - 1, j)) {
                        cnt++;
                    }
                }
                if (j > 1) {
                    if (check2(i, j - 1)) {
                        cnt++;
                    }
                }
                if (i < n) {
                    if (check2(i + 1, j)) {
                        cnt++;
                    }
                }
                if (j < m) {
                    if (check2(i, j + 1)) {
                        cnt++;
                    }
                }

                maxgx = max(maxgx, cnt);
                mp[i][j] = '#';
            }
        }
    }

    printf("%d", ans + maxgx);
    return 0;
}
80 pts\text{80 pts} 让我无话可说………………

回复

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

正在加载回复...