2025年12月 GESP CCF编程能力等级认证C++六级真题

========================================================================

答案和更多内容请查看网站:【试卷中心 -----> CCF GESP ----> C/C++ ----> 六级】

网站链接

青少年软件编程历年真题模拟题实时更新

========================================================================C

2025年12月 GESP CCF编程能力等级认证C++六级真题

一、单选题(每题 2 分,共 30 分)

第 1 题 在面向对象编程中,下列关于 虚函数 的描述中,错误的是( )。

A. 虚函数用于支持运行时多态

B. 通过基类指针调用虚函数时,会根据对象实际类型决定调用版本

C. 构造函数可以声明为虚函数以支持多态

D. 基类析构函数常声明为虚函数以避免资源泄漏

第 2 题 执行如下代码,会输出 钢琴:叮咚叮咚 和 吉他:咚咚当当 。这体现了面向对象编程的( )特性。

复制代码
class Instrument {
public:
    virtual void play()
    {
        cout << "乐器在演奏声音" << endl;
    }


    virtual ~Instrument()
    {
    }
};
class Piano : public Instrument {
public:
    void play() override
    {
        cout << "钢琴:叮咚叮咚" << endl;
    }
};
class Guitar : public Instrument {
public:
    void play() override
    {
        cout << "吉他:咚咚当当" << endl;
    }
};
int main()
{
    Instrument* instruments[2];
    instruments[0]    = new Piano();
    instruments[1]    = new Guitar();
    for ( int i = 0; i < 2; ++i )
    {
        instruments[i]->play();
    }
    for ( int i = 0; i < 3; ++i )
    {
        delete instruments[i];
    }
    return(0);
}

A. 继承

B. 封装

C. 多态

D. 链接

第 3 题 关于以下代码,说法正确的是( )。

复制代码
class Instrument {
public:
    void play()
    {
        cout << "乐器在演奏声音" << endl;
    }


    virtual ~Instrument()
    {
    }
};
class Piano : public Instrument {
public:
    void play() override
    {
        cout << "钢琴:叮咚叮咚" << endl;
    }
};
class Guitar : public Instrument {
public:
    void play() override
    {
        cout << "吉他:咚咚当当" << endl;
    }
};
int main()
{
    Instrument* instruments[2];
    instruments[0]    = new Piano();
    instruments[1]    = new Guitar();
    for ( int i = 0; i < 2; ++i )
    {
        instruments[i]->play();
    }
    for ( int i = 0; i < 3; ++i )
    {
        delete instruments[i];
    }
    return(0);
}

A. 执行代码会输出两行,内容分别为: 钢琴:叮咚叮咚 和 吉他:咚咚当当

B. 执行代码会输出两行,内容分别为: 乐器在演奏声音 和 乐器在演奏声音

C. 代码编译出现错误

D. 代码运行出现错误

第 4 题 某文本编辑器把用户输入的字符依次压入栈 S。用户依次输入 A , B , C , D 后,用户按了两次撤销(每次撤销,弹出栈顶一个字符)。此时栈从栈底到栈顶的内容是:( )。

A. A B

B. A B C

C. A B D

D. B C

第 5 题 假设循环队列数组长度为 N ,其中队空判断条件为: front == rear ,队满判断条件为: (rear + 1) %N == front ,出队对应的操作为: front = (front + 1) % N ,入队对于的操作为: rear = (rear + 1) %N 。循环队列长度 N = 6 ,初始 front = 1 , rear = 1 ,执行操作序列为:入队, 入队, 入队, 出队, 入队, 入队,则最终 (front, rear) 的值是( )。

A. (2, 5)

B. (2, 0)

C. (3, 5)

D. (3, 0)

第 6 题 以下函数 check() 用于判断一棵二叉树是否为( )。

复制代码
bool check( TreeNode* root )
{
    if ( !root )
        return(true);
    queue<TreeNode*> q;
    q.push( root );
    bool hasNull = false;
    while ( !q.empty() )
    {
        TreeNode* cur = q.front(); q.pop();
        if ( !cur )
        {
            hasNull = true;
        } else {
            if ( hasNull )
                return(false);
            q.push( cur->left );
            q.push( cur->right );
        }
    }
    return(true);
}

A. 满二叉树

B. 完全二叉树

C. 二叉搜索树

D. 平衡二叉树

第 7 题 以下代码实现了二叉树的( )。

复制代码
void traverse( TreeNode* root )
{
    if ( !root )
        return;
    traverse( root->left );
    traverse( root->right );
    cout << root->val << " ";
}

A. 前序遍历

B. 中序遍历

C. 后序遍历

D. 层序遍历

第 8 题 下面代码实现了哈夫曼编码,则横线处应填写的代码是( )。

复制代码
struct Symbol {
    char        ch;     /* 字符 */
    long long    freq;   /* 频率 */
    string        code;   /* 哈夫曼编码 */
};
struct Node {
    long long    w;      /* 权值 */
    int        l, r;   /* 左右孩子(节点下标),-1 表示空 */
    int        sym;    /* 叶子对应符号下标;内部节点为 -1 */
    Node( long long _w = 0, int _l = -1, int _r = -1, int _sym = -1 )
        : w( _w ), l( _l ), r( _r ), sym( _sym )
    {
    }
};
/* 从 A(leafIdx) 和 B(internalIdx) 的队首取最小的一个节点下标 */
static int PopMinNode( const vector<Node> & nodes,
               const vector<int> & leafIdx, int n, int & pA,
               const vector<int> & internalIdx, int & pB )
{
    if ( pA < n && (pB >= (int) internalIdx.size() ||
            nodes[leafIdx[pA]].w <= nodes[internalIdx[pB]].w) )
    {
        return(leafIdx[pA++]);
    }else  {
        return(internalIdx[pB++]);
    }
}


/* DFS 生成编码(左 0,右 1) */
static void DFSBuildCodes( int u, const vector<Node> & nodes, Symbol sym[], string & path )
{
    if ( u == -1 )
        return;
    if ( nodes[u].sym != -1 ) /* 叶子 */
    {
        sym[nodes[u].sym].code = path;
        return;
    }
    path.push_back( '0' );
    DFSBuildCodes( nodes[u].l, nodes, sym, path );
    path.pop_back();
    path.push_back( '1' );
    DFSBuildCodes( nodes[u].r, nodes, sym, path );
    path.pop_back();
}


int BuildHuffmanCodes( Symbol sym[], int n )
{
    for ( int i = 0; i < n; i++ )
        sym[i].code.clear();
    if ( n <= 0 )
        return(-1);
/* 只有一个字符:约定编码为 "0" */
    if ( n == 1 )
    {
        sym[0].code = "0";
        return(0);
    }
    vector<Node> nodes;
    nodes.reserve( 2 * n );
/* 1) 建立叶子节点 */
    vector<int> leafIdx( n );
    for ( int i = 0; i < n; i++ )
    {
        leafIdx[i] = (int) nodes.size();
        nodes.push_back( Node( sym[i].freq, -1, -1, i ) );
    }
/* 2) 叶子按权值排序(A 队列) */
    sort( leafIdx.begin(), leafIdx.end(),
          [&]( int a, int b ) {
              if ( nodes[a].w != nodes[b].w )
                  return(nodes[a].w < nodes[b].w);
              return(nodes[a].sym < nodes[b].sym); /* 稳定一下 */
          } );
/* B 队列(内部节点下标队列) */
    vector<int> internalIdx;
    internalIdx.reserve( n );
    int pA = 0, pB = 0;
/* 3) 合并 n-1 次 */
    for ( int k = 1; k < n; k++ )
    {
        int    x    = PopMinNode( nodes, leafIdx, n, pA, internalIdx, pB );
        int    y    = PopMinNode( nodes, leafIdx, n, pA, internalIdx, pB );
        int    z    = (int) nodes.size();
        ________________________ /* 在此处填写代码 */
    }
    int root = internalIdx.back();
/* 4) DFS 生成编码 */
    string path;
    DFSBuildCodes( root, nodes, sym, path );
    return(root);
}

A.

nodes.push_back(Node(nodes[x].w + nodes[y].w, x, y, -1));

internalIdx.push_back(z);

B.

nodes.push_back(Node(nodes[x].w + nodes[y].w, x, y, -1));

leafIdx.push_back(z);

C.

internalIdx.push_back(z);

nodes.push_back(Node(nodes[x].w + nodes[y].w, x, y, x+y));

D.

nodes.push_back(Node(nodes[x].w + nodes[y].w, x, y, x+y));

leafIdx.push_back(z);

第 9 题 以下关于哈夫曼编码的说法,正确的是( )。

A. 哈夫曼编码是定长编码

B. 哈夫曼编码中,没有任何一个字符的编码是另一个字符编码的前缀

C. 哈夫曼编码一定唯一

D. 哈夫曼编码不能用于数据压缩

第 10 题 以下函数实现了二叉排序树(BST)的( )操作。

复制代码
TreeNode* op( TreeNode* root, int x )
{
    if ( !root )
        return(new TreeNode( x ) );
    if ( x < root->val )
        root->left = op( root->left, x );
    else
        root->right = op( root->right, x );
    return(root);
}

A. 查找

B. 插入

C. 删除

D. 遍历

========================================================================

答案和更多内容请查看网站:【试卷中心 -----> CCF GESP ----> C/C++ ----> 六级】

网站链接

青少年软件编程历年真题模拟题实时更新

========================================================================

相关推荐
Terrence Shen18 小时前
【CUDA编程系列】之01
c++·人工智能·深度学习·机器学习
墨有66618 小时前
数学分析栈的出栈顺序:从算法判断到数学本质(卡特兰数初探)
c++·算法·数学建模
liulilittle18 小时前
LIBTCPIP 技术探秘(tun2sys-socket)
开发语言·网络·c++·信息与通信·通信·tun
yyy(十一月限定版)18 小时前
c++(3)类和对象(中)
java·开发语言·c++
DYS_房东的猫19 小时前
写出第一个程序
c++
ulias21219 小时前
AVL树的实现
开发语言·数据结构·c++·windows
山上三树19 小时前
详细介绍 C/C++ 中的内存泄漏
c语言·c++
CSDN_RTKLIB19 小时前
CMake构建目标核心命令
c++
郝学胜-神的一滴19 小时前
图形学中的纹理映射问题:摩尔纹与毛刺的深度解析
c++·程序人生·unity·游戏引擎·图形渲染·unreal engine