GESP2025年12月认证C++二级真题与解析(编程题2 (黄金格))

一、先看原题:

二、题目解析

1、📖 故事背景

小杨来到了一张 神奇地图 🗺️✨

地图是一个方格世界:

  • H 行

  • W 列

  • 每个格子都有坐标 (行号, 列号)

但是!

👉 不是所有格子都普通

👉 有些是 ✨ 黄金格


2、🧠 黄金格的秘密条件

一个格子 (r, c) 是黄金格,当:

cpp 复制代码
√(r² + c²) ≤ x + r - c

听起来吓人?😄

其实我们只要 照着算 就行!


3、🧩 程序思路(像走地图)

1️⃣ 一行一行看

2️⃣ 一列一列看

3️⃣ 对每个格子:

  • 计算左边

  • 计算右边

  • 判断能不能当黄金格

4️⃣ 能 → 计数 +1


4、💻 参考程序

cpp 复制代码
#include <iostream>
#include <cmath>
using namespace std;

int main() {
    int H, W, x;
    cin >> H >> W >> x;

    int ans = 0;  // 黄金格数量

    for (int r = 1; r <= H; r++) {
        for (int c = 1; c <= W; c++) {
            if (sqrt(r * r + c * c) <= x + r - c) {
                ans++;
            }
        }
    }

    cout << ans << endl;
    return 0;
}

5、🔍 逐行讲解

cpp 复制代码
#include <cmath>

👉 因为要用 sqrt()(开平方)


cpp 复制代码
for (int r = 1; r <= H; r++)

👉 在地图上 一行一行走


cpp 复制代码
for (int c = 1; c <= W; c++)

👉 每一行里,一列一列看


cpp 复制代码
sqrt(r * r + c * c)

👉 算左边的数学公式


cpp 复制代码
if ( ... )
    ans++;

满足条件 → 找到一个黄金格 ✨


6、 题目要点:

  • 双重 for 循环(二维地图)

  • 使用 sqrt() 数学函数

  • 把复杂条件写进 if


相关推荐
信奥胡老师37 分钟前
B3930 [GESP202312 五级] 烹饪问题
开发语言·数据结构·c++·学习·算法
许长安41 分钟前
Redis 跳表实现详解
数据库·c++·经验分享·redis·笔记·缓存
paeamecium1 小时前
【PAT甲级真题】- Shortest Distance (20)
数据结构·c++·算法·pat考试·pat
REDcker1 小时前
C++循环与编译器优化详解 别名不变量向量化与GCC Clang验证及perf实践
java·jvm·c++·c·clang·gcc
不剪发的Tony老师1 小时前
Code::Blocks:一款免费开源的C/C++/Fortran集成开发环境
c语言·c++·ide
咩咦1 小时前
C++学习笔记10:auto关键字
c++·学习笔记·c++11·auto·类型推导
csuzhucong1 小时前
c++版本特性
开发语言·c++
Peter·Pan爱编程2 小时前
继承不是“拿来用“:is-a 关系与组合
c++
.小小陈.2 小时前
Linux 多线程进阶:线程互斥、同步、线程池、死锁与线程安全、读写锁、自旋锁
linux·开发语言·c++
lingran__3 小时前
C++入门基础
开发语言·c++