CCF GESP 2025年12月认证 C++ 6级

判断题
共 10 道 每题 2 分 共计 20 分
第 1 题

以下代码中,构造函数被调用的次数是 1 次。

class Test {
public:
    Test() { cout << "T "; }
};
 
int main() {
    Test a;
    Test b = a;
}
正确
错误
第 2 题

面向对象编程中,封装是指将数据和操作数据的方法绑定在一起,并对外隐藏实现细节。

正确
错误
第 3 题

以下代码能够正确统计二叉树中叶子结点的数量。

int countLeaf(TreeNode* root) {
    if (!root) return 0;
    if (!root->left && !root->right) return 1;
    return countLeaf(root->left) + countLeaf(root->right);
}
正确
错误
第 4 题

广度优先遍历二叉树可用栈来实现。

正确
错误
第 5 题

函数调用管理可用栈来管理。

正确
错误
第 6 题

在二叉排序树(BST)中,若某结点的左子树为空,则该结点一定是整棵树中的最小值结点。

正确
错误
第 7 题

下面的函数能正确判断一棵树是不是二叉排序树(左边的数字要比当前数字小,右边的数字要比当前数字大)。

bool isBST(TreeNode* root, int minVal, int maxVal) {
    if (!root) return true;
    if (root->val <= minVal || root->val >= maxVal)
        return false;
    return isBST(root->left, minVal, root->val) &&
           isBST(root->right, root->val, maxVal);
}
正确
错误
第 8 题

格雷编码相邻两个编码之间必须有多位不同,以避免数据传输错误。

正确
错误
第 9 题

小杨在玩一个闯关游戏,从第 1 关走到第 4 关。每一关的体力消耗如下(下标表示关卡编号):cost = [0, 3, 5, 2, 4]。其中 cost[i] 表示到达第 i 关需要消耗的体力,cost[0]=0 表示在开始状态,体力消耗为 0。小杨每次可以从当前关卡前进 1 步或 2 步。按照上述规则,从第 1 关到第 4 关所需消耗的最小体力为 7。

正确
错误
第 10 题

假定只有一个根节点的树的深度为 1,则一棵有 n 个节点的完全二叉树,则树的深度为 $ \lfloor$ log2(n) $\rfloor +1$。

正确
错误
判断题部分已到底了。