GESP2025年9月认证C++四级( 第三部分编程题(1)排兵布阵)

参考程序1(完全暴力)

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

const int N = 15; // n,m <= 12,留一点余量
int a[N][N];

int main() {
    int n, m;
    cin >> n >> m;    //录入数据 
    for (int i = 1; i <= n; ++i) 
        for (int j = 1; j <= m; ++j)
            cin >> a[i][j];

    int ans = 0;
    // 枚举矩形:上(u)、左(l)、下(d)、右(r) 
    for (int u = 1; u <= n; ++u) {  
        for (int l = 1; l <= m; ++l) {
            for (int d = u; d <= n; ++d) {
                for (int r = l; r <= m; ++r) {
                    bool ok = true;
                    // 检查矩形 [u..d] x [l..r] 是否全为1
                    for (int i = u; i <= d && ok; ++i) {
                        for (int j = l; j <= r; ++j) {
                            if (a[i][j] == 0) { ok = false; break; }
                        }
                    }
                    if (ok) {
                        int area = (d - u + 1) * (r - l + 1);
                        if (area > ans) ans = area;
                    }
                }
            }
        }
    }

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

参考程序2(优化暴力)

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

const int N = 15;// n,m <= 12,留一点余量
int n, m;
int a[N][N];
int ans;
int main() {
	scanf("%d%d", &n, &m);
	for (int i = 1; i <= n; i++)
		for (int j = 1; j <= m; j++) 
			scanf("%d", &a[i][j]);
	for (int u = 1; u <= n; u++)
		for (int l = 1; l <= m; l++)
			for (int d = u; d <= n; d++) {
				int chk = 1;
				for (int r = l; r <= m; r++) {
					for (int x = u; x <= d; x++) 
						chk &= a[x][r];
					if (!chk) break;
					ans = max(ans, (r - l + 1) * (d - u + 1));
				}
			}
	printf("%d\n", ans);
	return 0;
}

参考程序3(直方图+单调栈)

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

int main() {
    int n, m;
    cin >> n >> m;
    vector<vector<int>> a(n, vector<int>(m));
    for (int i = 0; i < n; ++i)
      for (int j = 0; j < m; ++j)
        cin >> a[i][j];

    vector<int> h(m, 0);
    int ans = 0;
    for (int i = 0; i < n; ++i) {
        // 更新高度数组
        for (int j = 0; j < m; ++j) {
            if (a[i][j] == 1) h[j] += 1;
            else h[j] = 0;
        }
        // 求当前直方图最大矩形(单调栈,经典做法)
        stack<int> st;
        for (int j = 0; j <= m; ++j) {
            // 当 j==m 时,视为高度 0,促使清栈
            int curH = (j == m ? 0 : h[j]);
            while (!st.empty() && h[st.top()] > curH) {
                int height = h[st.top()]; st.pop();
                int left = st.empty() ? -1 : st.top();
                int width = j - left - 1;
                ans = max(ans, height * width);
            }
            st.push(j);
        }
    }
    cout << ans << "\n";
    return 0;
}
相关推荐
2401_8920709821 小时前
【Linux C++ 日志系统实战】LogFile 日志文件管理核心:滚动策略、线程安全与方法全解析
linux·c++·日志系统·日志滚动
yuzhuanhei21 小时前
Visual Studio 配置C++opencv
c++·学习·visual studio
小O的算法实验室21 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
不爱吃炸鸡柳1 天前
C++ STL list 超详细解析:从接口使用到模拟实现
开发语言·c++·list
十五年专注C++开发1 天前
RTTR: 一款MIT 协议开源的 C++ 运行时反射库
开发语言·c++·反射
‎ദ്ദിᵔ.˛.ᵔ₎1 天前
STL 栈 队列
开发语言·c++
2401_892070981 天前
【Linux C++ 日志系统实战】高性能文件写入 AppendFile 核心方法解析
linux·c++·日志系统·文件写对象
郭涤生1 天前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿1 天前
vector
c语言·开发语言·数据结构·c++·算法
cccyi71 天前
【C++ 脚手架】etcd 的介绍与使用
c++·服务发现·etcd·服务注册