GESP C++五级-202406

选择题










判断题






编程题

1. 黑白格


C++代码实现

cpp 复制代码
#include <iostream>
#include <string>
#include <algorithm>

using namespace std;

// 根据数据范围 n, m <= 100,给定略大的常量
const int N = 110;
const int INF = 1e9;

int n, m, k;
int s[N][N]; // s[i][j] 表示第 j 列前 i 行黑格子的数量(列前缀和)

int main() {
    // 优化输入效率(可选)
    ios::sync_with_stdio(false);
    cin.tie(0);

    if (!(cin >> n >> m >> k)) return 0;

    for (int i = 1; i <= n; i++) {
        string row;
        cin >> row;
        for (int j = 1; j <= m; j++) {
            int val = (row[j - 1] == '1' ? 1 : 0);
            s[i][j] = s[i - 1][j] + val; // 预处理列前缀和
        }
    }

    int ans = INF;
    bool found = false;

    // 枚举子矩形的上边界 i 和下边界 j
    for (int i = 1; i <= n; i++) {
        for (int j = i; j <= n; j++) {
            int height = j - i + 1;
            
            // 使用双指针(滑动窗口)维护列边界 l 和 r
            int sum = 0;
            for (int l = 1, r = 1; r <= m; r++) {
                sum += (s[j][r] - s[i - 1][r]); // 累加当前列在 [i, j] 行区间内的黑格子数

                // 当黑格子总数 >= k 时,尝试收缩左边界 l 以减小面积
                while (sum >= k) {
                    found = true;
                    ans = min(ans, height * (r - l + 1));
                    sum -= (s[j][l] - s[i - 1][l]);
                    l++;
                }
            }
        }
    }

    if (!found) cout << 0 << endl;
    else cout << ans << endl;

    return 0;
}

2. 小杨的幸运数字


C++代码实现

cpp 复制代码
#include <iostream>

using namespace std;

const int N = 1000010;

// cnt[i] 存储数字 i 的不同质因子个数
int cnt[N];
int n;

// 类似埃氏筛的预处理函数
void precompute() {
    for (int i = 2; i < N; i++) {
        // 如果 cnt[i] 仍为 0,说明 i 是一个质数
        if (cnt[i] == 0) {
            // 将该质数的所有倍数的质因子计数加 1
            for (int j = i; j < N; j += i) {
                cnt[j]++;
            }
        }
    }
}

int main() {
    // 优化输入输出效率
    ios::sync_with_stdio(false);
    cin.tie(0);

    // 执行预处理
    precompute();

    if (!(cin >> n)) return 0;

    while (n--) {
        int a;
        cin >> a;
        // 如果不同质因子个数恰好为 2,输出 1,否则输出 0
        if (cnt[a] == 2) {
            cout << 1 << "\n";
        } else {
            cout << 0 << "\n";
        }
    }

    return 0;
}


C++代码实现

cpp 复制代码
#include <iostream>

using namespace std;

const int N = 1000010;

// cnt[i] 存储数字 i 的不同质因子个数
int cnt[N];
int n;

// 类似埃氏筛的预处理函数
void precompute() {
    for (int i = 2; i < N; i++) {
        // 如果 cnt[i] 仍为 0,说明 i 是一个质数
        if (cnt[i] == 0) {
            // 将该质数的所有倍数的质因子计数加 1
            for (int j = i; j < N; j += i) {
                cnt[j]++;
            }
        }
    }
}

int main() {
    // 优化输入输出效率
    ios::sync_with_stdio(false);
    cin.tie(0);

    // 执行预处理
    precompute();

    if (!(cin >> n)) return 0;

    while (n--) {
        int a;
        cin >> a;
        // 如果不同质因子个数恰好为 2,输出 1,否则输出 0
        if (cnt[a] == 2) {
            cout << 1 << "\n";
        } else {
            cout << 0 << "\n";
        }
    }

    return 0;
}
相关推荐
灰子学技术7 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
二十雨辰8 小时前
[python]-AI大模型
开发语言·人工智能·python
Doro再努力8 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
Yvonne爱编码8 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚8 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
Daniel李华8 小时前
echarts使用案例
android·javascript·echarts
你这个代码我看不懂8 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
pas1368 小时前
41-parse的实现原理&有限状态机
开发语言·前端·javascript
琹箐8 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
Monly219 小时前
Java:修改打包配置文件
java·开发语言