#G4105. [GESP202406 四级] 客观题

[GESP202406 四级] 客观题

单选题

  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
  1. 下面函数不能正常执行的是( )

    {{ select(2) }}

  1. 下面程序输出的是()

    #include<iostream>
    using namespace std;
    int func();
    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
  1. 假设变量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
  1. 如果下列程序输出的地址是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
  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) }}

  • A. 插入排序的最好情况是数组已经有序,此时只需要进行 (n-1) 次比较,时间复杂度为 (O(n))
  • B. 最坏情况是数组逆序排序,此时需要进行 (n(n-1)/2) 次比较以及 (n-1) 次赋值操作(插入)
  • C. 平均来说插入排序算法的复杂度为 (O(n^2))
  • D. 空间复杂度上,直接插入法是就地排序,空间复杂度为 (O(n))
  1. 下列程序横线处,应该输入的是()。

    #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++) {
            for(int j=1;j++) {
                if(a[j]>a[j+1])
                    ______
            }
        }
        for(int i=1;i<n;i++)
            cout<<a[i]<<" ";
        cout<<endl;
        return 0;
    }
    

    {{ 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) }}

  • 递推表现为自己调用自己
  • 递推是从简单问题出发,一步步的向前发展,最终求得问题。是正向的
  • 递推中,问题的要求是在计算中确定,不要求计算前就知道
  • 斐波那契数列可以用递推实现求解
  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. 下面的排序算法程序中,横线处应该填入的是( )。

    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];
  1. 下面的程序中,如果输入 ( 10 \quad 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
  1. 10条直线,最多可以把平面分为多少个区域()。

    {{ select(14) }}

  • 55
  • 56
  • 54
  • 58
  1. 下面程序中,如果语句 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

判断题

  1. int & a 和 &a 是一样的,都是取 a 的地址。

    {{ select(16) }}

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

    #include<iostream>
    using namespace std;
    int main() {
        int a=20;
        int & ra;
        ra=&a;
        cout<<ra<<endl;
    }
    

    {{ select(17) }}

  1. 引用是一个指针常量。

    {{ select(18) }}

  1. 下面程序两个输出结果是一样的。

    #include<iostream>
    using namespace std;
    int main() {
        int a[2][3]={0};
        cout<<a<<endl;
        cout<<&a[0][0]<<endl;
    }
    

    {{ select(19) }}

  1. 函数不可以调用自己。

    {{ select(20) }}

  1. 函数参数传递过程中,如果传常量值、常量引用和常量指针都是不能被修改的,它们可以防止函数对实参的值或地址进行修改。

    {{ select(21) }}

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

    #include<iostream>
    using namespace std;
    int main() {
        int *p=NULL;
        cout<<p<<endl;
    }
    

    {{ select(22) }}

  1. 在下面这个程序里,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) }}

  1. 一个一维数组,至少含有一个自然数N,是一个合法的数列。可以在一维数组末尾加入一个自然数M,M不能超过一维数组末尾元素的一半,形成一个新的合法的一维数组。如果N=6,那么可以有6个不同的合法数组。

    {{ select(24) }}

  1. 插入排序算法中,平均时间复杂度是(O(n^2)),最坏的情况逆序情况下,达到最大时间复杂度。

    {{ select(25) }}