GESP C++ 真题 · 逐题精解
首页C++八级真题 › 2025年6月 › 第9题

GESP 2025年6月 C++八级 单选题 第9题

C++八级单选题2025年6月第9题

所属知识点:各类算法复杂度 难度要求:掌握 考频:中频

下面 sum_digit 函数求 1 到 n 中包含数字 d 的个数,其时间复杂度为:
int count_digit(int n, char d) {
    int cnt = 0;
    std::string s = std::to_string(n);
    for (int i = 0; i < s.length(); i++)
        if (s[i] == d) cnt++;
    return cnt;
}
int sum_digit(int n, char d) {
    int sum = 0;
    for (int i = 1; i <= n; i++)
        sum += count_digit(i, d);
    return sum;
}

正确答案:A

题目解析

外层循环 n 次,每次 count_digit 遍历该数的各位数字 O(lo………

完整解析为会员内容二级及以上的逐题精讲需开通 VIP。一级解析全部免费。前往 GESPPASS 解锁

想系统刷完 GESP C++ 1~8 级真题,并查看每道题的逐题精讲?

进入 GESPPASS 开始练习