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


相关推荐
lightqjx1 天前
【算法】前缀和
c++·算法·leetcode·前缀和
汉克老师1 天前
GESP5级C++考试语法知识(七、链表(二)双链表)
c++·链表·双链表·gesp5级·gesp五级
旖-旎1 天前
二分查找(寻找旋转排序数组中的最小值)(7)
c++·算法·二分查找·力扣
C羊驼1 天前
C/C++数据结构与算法:穷举法
c语言·c++·笔记·学习·算法
十五年专注C++开发1 天前
libuv:一个跨平台的C++异步 I/O 库
开发语言·c++·node.js·libuv·vlibuv
qq_417695051 天前
C++中的解释器模式
开发语言·c++·算法
xiaoye-duck1 天前
《算法题讲解指南:动态规划算法--路径问题》--9.最小路径和,10.地下城游戏
c++·算法·动态规划
刺客xs1 天前
c++模板
java·开发语言·c++
2301_818419011 天前
C++中的状态模式实战
开发语言·c++·算法
仰泳的熊猫1 天前
题目2576:蓝桥杯2020年第十一届省赛真题-解码
数据结构·c++·算法·蓝桥杯