#J6002. CCF-GESP编程能力等级认证真题【C062312】

CCF-GESP编程能力等级认证真题【C062312】

一、选择题。(15题,每题2分,共30分)

1. 关于C++类和对象的说法,错误的是?
{{ select(1) }}

  • 在C++中,一切皆对象,即便是字面量如整数5等也是对象
  • 在C++中,可以自定义新的类,并实例化为新的对象
  • 在C++中,内置函数和自定义函数,都是类或者对象
  • 在C++中,可以在自定义函数中嵌套定义新的函数

2. 有关下面C++代码的说法,错误的是?

image

{{ select(2) }}

  • C++中类内部可以嵌套定义类
  • 在类中定义的类被称为内部类,定义类的类被称为外部类
  • 内部类可以随便访问,不需要通过外部类来访问
  • 代码中 Point 被称为内部类,可以通过外部类 Rectangle 来访问, Rectangle::Point

3. 有关下面C++代码的说法,正确的是?

image

{{ select(3) }}

  • 第14行代码错误,第15行正确
  • 第15行代码错误,第14行代码正确
  • 第14、15两行代码都正确
  • 第6行代码可修改为 objCounter += 1​

4. 有关下面C++代码的说法,错误的是?

image

{{ select(4) }}

  • 上列C++代码适用于构造各种二叉树
  • 代码 struct BiNode 用于构造二叉树的节点
  • 代码 BiTree(){root=Creat();} 用于构造二叉树
  • 析构函数不可以省略​

5. 基于第4题的定义,有关下面C++代码的说法正确的是?

image

{{ select(5) }}

  • 代码中 Order( ) 函数是中序遍历二叉树的方法
  • 代码中 Order( ) 先访问根节点,然后对左子树进行前序遍历,再对右子树前序遍历
  • 代码中 Order( ) 先访问中序遍历左子树,然后访问根节点,最后则是中序遍历右子树​
  • 代码中 Order( ) 先后序遍历左子树,然后后序遍历右子树,最后访问根节点

6. 有关下面C++代码的说法正确的是?

image

{{ select(6) }}

  • 上述代码构成单向链表
  • 上述代码构成双向链表
  • 上述代码构成循环链表​
  • 上述代码构成指针链表

7. 对 hello world 使用霍夫曼编码(Huffman Coding),最少bit(比特)为?
{{ select(7) }}

  • 4
  • 32
  • 64
  • 88​

8. 下面的 fiboA() 和 fiboB() 两个函数分别实现斐波那契数列,该数列第1、第2项值为1,其余各项分别为前两项之和。下面有关说法错误的是?

image

{{ select(8) }}

  • fiboA() 采用递归方式实现斐波那契数列
  • fiboB() 采用动态规划算法实现斐波那契数列
  • 当N值较大时, fiboA() 存在大量重复计算
  • 由于 fiboA() 代码较短,其执行效率较高​

9. 有关下面C++代码不正确的说法是?

image

{{ select(9) }}

  • 该代码可用于求解二叉树的深度
  • 代码中函数 Depth( ) 的参数 T 表示根节点,非根节点不可以作为参数
  • 代码中函数 Depth( ) 采用了递归方法
  • 代码中函数 Depth( ) 可用于求解各种形式的二叉树深度,要求该二叉树节点至少有 left 和 right 属性​

10. 下面有关树的存储,错误的是?
{{ select(10) }}

  • 完全二叉树可以用 list 存储
  • 一般二叉树都可以用 list 存储,空子树位置可以用 None 表示
  • 满二叉树可以用 list 存储
  • 树数据结构,都可以用 list 存储​

11. 构造二叉树 [1,2,3,null,4]

![image](file://CGqX6QIMc2gaDJUc2V5TP.png)

{{ select(11) }}

  • 1(2()(4))(3)
  • 1(2(3)())(4)
  • (1,2(3),(4))
  • (1,(2)(3),(4))

12. 下面有关布尔类型的函数的说法,正确的是? {{ select(12) }}

  • bool 类型函数只能返回0或者1两种值
  • bool 类型函数可以返回任何整数值
  • bool 类型函数必须有参数传递
  • bool 类型函数没有返回值​

13. 通讯卫星在通信网络系统中主要起到( )的作用?
{{ select(13) }}

  • 信息过滤
  • 信号中继
  • 避免攻击
  • 数据加密

14. 小杨想编写一个判断任意输入的整数NN是否为素数的程序,下面哪个方法不合适?
{{ select(14) }}

  • 埃氏筛法
  • 线性筛法
  • 二分答案
  • 枚举法

15. 内排序有不同的类别,下面哪种排序算法和冒泡排序是同一类?
{{ select(15) }}

  • 希尔排序
  • 快速排序
  • 堆排序
  • 插入排序​

二、判断题​。(10题,每题2分,共20分)

16. 在面向对象中,方法在C++的class中表现为class内定义的函数。
{{ select(16) }}



17. C++类的定义中,可以没有构造函数,会给出默认的构造函数。
{{ select(17) }}



18. 如果某个C++对象(object)支持下标运算符(方括号运算符),则该对象在所对应class中以成员函数的形式进行了重载。
{{ select(18) }}



19. 深度优先搜索(DFS,Depth First Search的简写)属于图算法,其过程是对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次。
{{ select(19) }}



20. 哈夫曼编码(Huffman Coding)具有唯一性,因此有确定的压缩率。
{{ select(20) }}



21. 在下面C++代码中,由于删除了变量 ptr ,因此 ptr 所对应的数据也随之删除,故第8行代码被执行时,将报错。

image

{{ select(21) }}



22. 二叉搜索树查找的平均时间复杂度为O(logN)O(log N)
{{ select(22) }}



23. 二叉搜索树可以是空树(没有任何节点)或者单节点树(只有一个节点),或者多节点。如果是多节点,则左节点的值小于父节点的值,右节点的值大于父节点的值,由此推理,右节点树的值都大于根节点的值,左节点树的值都小于根节点的值。
{{ select(23) }}



24. 小杨想写一个程序来算出正整数NN有多少个因数,经过思考他写出了一个重复没有超过N/2N/2次的循环就能够算出来了。
{{ select(24) }}



25. 同样的整数序列分别保存在单链表和双向链中,这两种链表上的简单冒泡排序的复杂度相同。
{{ select(25) }}



三、​编程题。(2题,每题25分,共50分)

1. 【闯关游戏】

2. 【工作沟通