第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(4、最大空白区)

参考程序1:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main() {

    int N, M;
    cin >> N >> M;
    vector<vector<int>> grid(N, vector<int>(M));
    for (int i = 0; i < N; ++i)
        for (int j = 0; j < M; ++j)
            cin >> grid[i][j];

    // 构建二维前缀和,sum[i][j] 表示从 (0,0) 到 (i-1,j-1) 的格子中有多少个1
    vector<vector<int>> sum(N+1, vector<int>(M+1, 0));
    for (int i = 1; i <= N; ++i) {
        for (int j = 1; j <= M; ++j) {
            sum[i][j] = sum[i-1][j] + sum[i][j-1] - sum[i-1][j-1] + grid[i-1][j-1];
        }
    }

    int maxArea = 0;

    // 枚举所有左上角 (r1,c1) 和右下角 (r2,c2)
    for (int r1 = 0; r1 < N; ++r1) {
        for (int c1 = 0; c1 < M; ++c1) {
            for (int r2 = r1; r2 < N; ++r2) {
                for (int c2 = c1; c2 < M; ++c2) {
                    // 使用前缀和快速计算矩形内的格子和
                    int total = sum[r2+1][c2+1] - sum[r1][c2+1] - sum[r2+1][c1] + sum[r1][c1];
                    if (total == 0) { // 全是空白
                        int area = (r2-r1+1) * (c2-c1+1);
                        maxArea = max(maxArea, area);
                    }
                }
            }
        }
    }

    cout << maxArea << "\n";
    return 0;
}

参考程序2:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main() {

    int N, M;
    cin >> N >> M;
    vector<vector<int>> grid(N, vector<int>(M));
    for (int i = 0; i < N; ++i)
        for (int j = 0; j < M; ++j)
            cin >> grid[i][j];

    int maxArea = 0;

    // 枚举上边界 r1
    for (int r1 = 0; r1 < N; ++r1) {
        vector<int> col(M, 1); // 初始化每列为全空白(有效列)
        // 枚举下边界 r2 >= r1
        for (int r2 = r1; r2 < N; ++r2) {
            // 更新每列是否在 r1~r2 行之间全是空白
            for (int c = 0; c < M; ++c) {
                if (grid[r2][c] == 1) col[c] = 0; // 有草则列无效
            }
            // 找 col 中最长连续 1 的长度
            int width = 0;
            int maxWidth = 0;
            for (int c = 0; c < M; ++c) {
                if (col[c] == 1) width++;
                else width = 0;
                maxWidth = max(maxWidth, width);
            }
            int height = r2 - r1 + 1;
            maxArea = max(maxArea, maxWidth * height);
        }
    }

    cout << maxArea << "\n";
    return 0;
}
相关推荐
贾斯汀玛尔斯12 小时前
每天学一个算法--缓存淘汰策略(LRU / LFU · 结构与复杂度)
算法·缓存
大熊背12 小时前
一套为硬件加速设计的经典边缘检测流水线(一)----边缘细化原理
人工智能·算法·计算机视觉·梯度计算
MicroTech202512 小时前
微算法科技(NASDAQ :MLGO)基于线检测掩模的量子算法与新型增强量子表示(NEQR)技术
科技·算法·量子计算
yongui4783413 小时前
NSGA-II求解多目标柔性作业车间调度算法(含甘特图绘制)
算法·甘特图
ximu_polaris13 小时前
设计模式(C++)-行为型模式-观察者模式
c++·观察者模式·设计模式
故事和你9114 小时前
洛谷-算法2-1-前缀和、差分与离散化1
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
知识浅谈21 小时前
DeepSeek V4 和 GPT-5.5 在同一天发布了??我也很懵,但对比完我悟了
算法
DeepModel21 小时前
通俗易懂讲透 Q-Learning:从零学会强化学习核心算法
人工智能·学习·算法·机器学习
田梓燊21 小时前
力扣:19.删除链表的倒数第 N 个结点
算法·leetcode·链表
handler011 天前
从零实现自动化构建:Linux Makefile 完全指南
linux·c++·笔记·学习·自动化