0 #J4005. CCF-GESP编程能力等级认证真题【C042406】

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

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

  1. 下列代码中,输出结果是?

{{ select(1) }}

  • 12 24 24 12
  • 24 12 12 24
  • 12 12 24 24
  • 24 24 12 12

  1. 下⾯函数不能正常执⾏的是? {{ select(2) }}


  1. 下⾯程序输出的是?

{{ select(3) }}

  • 2 2 3 9
  • 2 10 3 9
  • 2 10 11 121
  • 2 10 3 100

  1. 假设变量 a 的地址是 0x6ffe14,下⾯程序的输出是?

{{ select(4) }}

  • 10
  • 0x6ffe14
  • 0x6ffe15
  • 0x6ffe18

  1. 如果下列程序输出的地址是 0x6ffe00 ,则 cout<<a+1<<endl; 输出的是?

{{ select(5) }}

  • 0x6ffe04
  • 0x6ffe0C
  • 0x6ffe08
  • 0x6ffe00

  1. C++中,关于⽂件路径说法错误的是? {{ select(6) }}
  • "GESP.txt":指定与当前⼯作⽬录中的程序⽂件相同⽬录中的 GESP.txt ⽂件
  • "../data/GESP.txt":指定与当前⼯作⽬录中的程序⽂件上⼀级⽬录下的 data ⽬录中的 GESP.txt ⽂件
  • "./data/GESP.txt":指定与当前⼯作⽬录中的程序⽂件同级⽬录下的 data ⽬录中的 GESP.txt ⽂件
  • "GESP.txt"是绝对路径

  1. 关于直接插⼊排序,下列说法错误的是? {{ select(7) }}
  • 插⼊排序的最好情况是数组已经有序,此时只需要进⾏ n1n-1 次⽐较,时间复杂度为O(n)O(n)
  • 最坏情况是数组逆序排序,此时需要进⾏ n(n1)/2n(n-1) /2 次⽐较以及 n1n-1 次赋值操作(插⼊)
  • 平均来说插⼊排序算法的复杂度为O(n2)O(n^2)
  • 空间复杂度上,直接插⼊法是就地排序,空间复杂度为O(n)O(n)

  1. 下列程序横线处,应该输⼊的是?

{{ select(8) }}

  • swap(a[j],a[j+1]);
  • swap(a[j-1],a[j]);
  • swap(a[j-1],a[j+1]);
  • swap(&a[j-1],&a[j+1]);

  1. 下⾯关于递推的说法不正确的是? {{ select(9) }}
  • 递推表现为⾃⼰调⽤⾃⼰
  • 递推是从简单问题出发,⼀步步的向前发展,最终求得问题。是正向
  • 递推中,问题的n要求是在计算中确定,不要求计算前就知道n
  • 斐波那契数列可以⽤递推实现求解

  1. 关于⼏种排序算法的说法,下⾯说法错误的是? {{ select(10) }}
  • 选择排序不是⼀个稳定的排序算法
  • 冒泡排序算法不是⼀种稳定的排序算法
  • 插⼊排序是⼀种稳定的排序算法
  • 如果排序前2个相等的数在序列中的前后位置顺序和排序后它们2个的前后位置顺序相同,则称为⼀种稳定的排序算法

  1. 数组{45,66,23,1,10,97,52,88,5,33}进⾏从⼩到⼤冒泡排序过程中,第⼀遍冒泡过后的序列是? {{ select(11) }}
  • {45,23,1,10,66,52,88,5,33,97}
  • {45,66,1,23,10,97,52,88,5,33}
  • {45,66,23,1,10,52,88,5,33,97}
  • {45,66,23,1,10,97,52,88,33,5}

  1. 下⾯的排序算法程序中,横线处应该填⼊的是?

{{ select(12) }}

  • a[j]=a[j-1];
  • a[j]=a[j+1];
  • a[j+1]=a[j-1];
  • a[j+1]=a[j];

  1. 下⾯的程序中,如果输⼊ 10 0,会输出?

{{ select(13) }}

  • Division by zero condition!
  • 0
  • 10
  • 100

  1. 10条直线,最多可以把平⾯分为多少个区域? {{ select(14) }}
  • 55
  • 56
  • 54
  • 58

  1. 下⾯程序中,如果语句 cout<<p<<endl; 输出的是 0x6ffe00 ,则 cout<<++p<<endl; 输出的是?

{{ select(15) }}

  • 0x6ffe0c
  • 0x6ffe09
  • 0x6ffe06
  • 0x6ffe04

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

  1. int& a 和&a是⼀样的,都是取a的地址。 {{ select(16) }}


  1. 以下代码不能够正确执⾏。

{{ select(17) }}



  1. 引⽤是⼀个指针常量。 {{ select(18) }}


  1. 下⾯程序两个输出结果是⼀样的。

{{ select(19) }}



  1. 函数不可以调⽤⾃⼰。 {{ select(20) }}


  1. 函数参数传递过程中,如果传常量值、常量引⽤和常量指针都是不能被修改的,它们可以防⽌函数对实参的值或地址进⾏修改。 {{ select(21) }}


  1. 下⾯代码输出的值等于0。

{{ select(22) }}



  1. 在下⾯这个程序⾥,a[i][j] 和⼀个普通的整型变量⼀样使⽤。

{{ select(23) }}



  1. ⼀个⼀维数组,⾄少含有⼀个⾃然数N,是⼀个合法的数列。可以在⼀维数组末尾加⼊⼀个⾃然数M,M不能超过⼀维数组末尾元素的⼀半,形成⼀个新的合法的⼀维数组,如果N=6,那么可以有6个不同的合法数组。 {{ select(24) }}


  1. 插⼊排序算法中,平均时间复杂度是 O(n2)O(n^2),最坏的情况逆序情况下,达到最⼤时间复杂度。 {{ select(25) }}


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

  1. 【⿊⽩⽅块】

  2. 【宝箱】