#84. [GESP202406 四级] 客观题
[GESP202406 四级] 客观题
一、单选题(每题2分,共30分)
第1题. 下列代码中,输出结果是( )。
#include<iostream>
using namespace std;
int func(int x,int y){
int a=x,b=y;
int t;
t=a;
a=b;
b=t;
cout<<a<<" "<<b<<" ";
}
int main() {
int c,d;
c=12;
d=24;
func(12,24);
cout<<c<<" "<<d<<endl;
}
{{ select(1) }}
- 12 24 24 12
- 24 12 12 24
- 12 12 24 24
- 24 24 12 12
第2题. 下⾯函数不能正常执⾏的是( )。
{{ select(2) }}
- 选项A
- 选项B
- 选项C
- 选项D
第3题. 下下⾯程序输出的是( )。
#include<iostream>
using namespace std;
int main() {
int i=2;
cout<<i<<endl;
for(int x=0;x<1;x++){
int i=10;
cout<<i<<endl;
}
i=i+1;
cout<<i<<endl;
{
i=i*i;
cout<<i<<endl;
}
}
{{ select(3) }}
- 2 2 3 9
- 2 10 3 9
- 2 10 11 121
- 2 10 3 100
第4题. 假设变量 a 的地址是0x6ffe14,下⾯程序的输出是( )。
#include<iostream>
using namespace std;
int main() {
int *p;
int a=10;
p=&a;
p++;
cout<<p<<endl;
}
{{ select(4) }}
- 10
- 0x6ffe14
- 0x6ffe15
- 0x6ffe18
第5题. 如果下列程序输出的地址是 0x6ffe00 ,则 cout<<a+1<<endl; 输出的是( )。
#include<iostream>
using namespace std;
int main() {
int a[2][3]={0};
cout<<a<<endl;
}
{{ select(5) }}
- 0x6ffe04
- 0x6ffe0C
- 0x6ffe08
- 0x6ffe00
第6题. C++中,关于⽂件路径说法错误的是( )。
{{ select(6) }}
- "GESP.txt":指定与当前⼯作⽬录中的程序⽂件相同⽬录中的 GESP.txt ⽂件
- "../data/GESP.txt":指定与当前⼯作⽬录中的程序⽂件上⼀级⽬录下的 data ⽬录中的 GESP.txt ⽂件
- "./data/GESP.txt":指定与当前⼯作⽬录中的程序⽂件同级⽬录下的 data ⽬录中的 GESP.txt ⽂件
- "GESP.txt"是绝对路径
第7题. 关于直接插⼊排序,下列说法错误的是( )。
{{ select(7) }}
- 插⼊排序的最好情况是数组已经有序,此时只需要进⾏n-1次比较,时间复杂度为O(n)
- 最坏情况是数组逆序排序,此时需要进⾏n(n01)/2次比较以及n-1次复制操作(插入)
- 平均来说插⼊排序算法的复杂度为O(n2)
- 空间复杂度上,直接插⼊法是就地排序,空间复杂度为O(n)
第8题. 下列程序横线处,应该输⼊的是( )。
#include<iostream>
using namespace std;
int n,a[10001];
void swap(int &a,int &b){
int t=a;
a=b;
b=t;
}
int main() {
cin>>n;
for(int i=1;i<=n;i++)
cin>>a[i];
for(int i=n;i>1;i--)
for(int j=1;j<i;j++)
if(a[j]>a[j+1])
________ //在此处填入代码
for(int i=1;i<=n;i++)
cout<<a[i]<<" ";
cout<<endl;
}
{{ 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]);
第9题. 下⾯关于递推的说法不正确的是( )。
{{ select(9) }}
- 递推表现为⾃⼰调⽤⾃⼰
- 递推是从简单问题出发,⼀步步的向前发展,最终求得问题。是正向的
- 递推中,问题的n要求是在计算中确定,不要求计算前就知道n
- 斐波那契数列可以⽤递推实现求解
第10题. 关于⼏种排序算法的说法,下⾯说法错误的是( )。
{{ select(10) }}
- 选择排序不是⼀个稳定的排序算法
- 冒泡排序算法不是⼀种稳定的排序算法
- 插⼊排序是⼀种稳定的排序算法
- 如果排序前2个相等的数在序列中的前后位置顺序和排序后它们2个的前后位置顺序相同,则称为⼀种稳定的排序算法
第11题. 数组{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}
第12题. 下⾯的排序算法程序中,横线处应该填⼊的是( )。
int a[8]= {2,3,4,5,6,2,3,1};
for(int i=1; i<8; i++) {
int key=a[i];
int j=i-1;
while(a[j]>key && j>=0) {
________ //在此处填入代码
j-=1;
}
a[j+1]=key;
}
{{ select(12) }}
- a[j]=a[j-1];
- a[j]=a[j+1];
- a[j+1]=a[j-1];
- a[j+1]=a[j];
第13题. 下⾯的程序中,如果输⼊ 10空格0 ,会输出( )。
#include<iostream>
using namespace std;
double Division(int a,int b){
if(b==0)
throw "Division by zero condition!";
else
return ((double)a / (double)b);
}
void func(){
int len,time;
cin>>len>>time;
cout<<Division(len,time)<<endl;
}
int main() {
try{
func();
}
catch(const char* errmsg){
cout<<errmsg<<endl;
}
catch(const int errmsg){
cout<<errmsg<<endl;
}
return 0;
}
{{ select(13) }}
- Division by zero condition!
- 0
- 10
- 100
第14题. 10条直线,最多可以把平⾯分为多少个区域( )。
{{ select(14) }}
- 55
- 56
- 54
- 58
第15题. 下⾯程序中,如果语句 cout<<p<<endl; 输出的是 0x6ffe00 ,则 cout<<++p<<endl; 输出的是。( )
int x[10][10][10]={0};
int *p;
p=&x[0][0][0];
cout<<p<<endl;
cout<<++p<<endl;
{{ select(15) }}
- 0x6ffe0c
- 0x6ffe09
- 0x6ffe06
- 0x6ffe04
二、判断题(每题2分,共20分)
第16题. int& a 和 &a 是⼀样的,都是取 a 的地址。( ) {{ select(16) }}
- √
- ×
第17题. 以下代码不能够正确执⾏。( )
#include<iostream>
using namespace std;
int main() {
int a=20;
int& ra;
ra=&a;
cout<<ra<<endl;
}
{{ select(17) }}
- √
- ×
第18题. 引⽤是⼀个指针常量。( )
{{ select(18) }}
- √
- ×
第19题. 下⾯程序两个输出结果是⼀样的。( )
#include<iostream>
using namespace std;
int main() {
int a[2][3]={0};
cout<<a<<endl;
cout<<&a[0][0]<<endl;
}
{{ select(19) }}
- √
- ×
第20题. 函数不可以调⽤⾃⼰。( )
{{ select(20) }}
- √
- ×
第21题. 函数参数传递过程中,如果传常量值、常量引⽤和常量指针都是不能被修改的,它们可以防⽌函数对实参的 值或地址进⾏修改。( )
{{ select(21) }}
- √
- ×
第22题. 下⾯代码输出的值等于0。( )
#include<iostream>
using namespace std;
int main() {
int *p=NULL;
cout<<p<<endl;
}
{{ select(22) }}
- √
- ×
第23题. 在下⾯这个程序⾥, a[i][j] 和⼀个普通的整型变量⼀样使⽤。( )
#include<iostream>
using namespace std;
int main() {
int a[10][10]={0};
for(int i=0;i<10;i++){
for(int j=0;j<10;j++){
if(i==j){
a[i][j]=1;
}
}
}
}
{{ select(23) }}
- √
- ×
第24题. ⼀个⼀维数组,⾄少含有⼀个⾃然数N,是⼀个合法的数列。可以在⼀维数组末尾加⼊⼀个⾃然数M,M不能超过⼀维数组末尾元素的⼀半,形成⼀个新的合法的⼀维数组,如果N=6,那么可以有6个不同的合法数组。( )
{{ select(24) }}
- √
- ×
第25题. 插⼊排序算法中,平均时间复杂度是 ,最坏的情况逆序情况下,达到最⼤时间复杂度。( )
{{ select(25) }}
- √
- ×