备战秋招 | 笔试强训9

目录

一、选择题

二、编程题

三、选择题题解

四、编程题题解


一、选择题

1、某函数申明如下()

void Func(int &nVal1);

A. Func(a)

B. Func(&a)

C. Func(*a)

D. Func(&(*a))

2、C++语言中,类ClassA的构造函数和析构函数的执行次数分别为()

ClassA *pclassa=new ClassA[5];
delete pclassa;

A. 5,1

B. 1,1

C. 5,5

D. 1,5

3、动态内存分配(C语言中malloc,C++中的new)得到的存储区属于内存中的:

A. 静态区

B. 堆(heap)

C. 栈(stack)

D. 堆栈

E. 内核内存

F. 不确定

4、下列静态数据成员的特性中,错误的是()

A. 引用静态数据成员时,要在静态数据成员名前加和作用域符号

B. 说明静态数据成员时前边要加关键字static来修饰

C. 静态数据成员在类体外进行初始化

D. 静态数据成员不是所有对象所共有的

5、用class关键字定义的类,其成员默认的访问属性为()

A. private

B. protected

C. public

D. 无定义

6、在重载一个运算符为成员函数时,其参数表中没有任何参数,这说明该运算符是 ( )。

A. 无操作数的运算符

B. 二元运算符

C. 前缀一元运算符

D. 后缀一元运算符

7、有如下程序:运行时的输出结果是

#include<iostream>
using namespace std;
class MyClass
{
    public:
    MyClass(int i=0){cout<<1;}
    MyClass(const MyClass&x){cout<<2;}
    MyClass& operator=(const MyClass&x){cout<<3; return*this;}
    ~MyClass(){cout<<4;}
};
int main()
{
    MyClass obj1(1),obj2(2),obj3(obj1);
    return 0;
}

A. 121,444

B. 112,444

C. 11,114,444

D. 11,314,445

E. 11,314,444

8、下面有关c++静态数据成员,说法正确的是()

A. 不能在类内初始化

B. 不能被类的对象调用

C. 不能受private修饰符的作用

D. 可以直接用类名调用

9、在C++中,为了让某个类只能通过new来创建(即如果直接创建对象,编译器将报错),应该()

A. 将构造函数设为私有

B. 将析构函数设为私有

C. 将构造函数和析构函数均设为私有

D. 没有办法能做到

10、下列的模板声明中,其中几个是正确的()

1)template
2)template<T1,T2>
3)template<class T1,T2>
4)template<class T1,class T2>
5)template<typename T1,T2>
6)template<typename T1,typename T2>
7)template<class T1,typename T2>
8)<typename T1,class T2>

A. 2

B. 3

C. 4

D. 5

二、编程题

1、另类加法  题目链接

2、走方格的方案数  题目链接 

三、选择题题解

1、某函数声明如下()

void Func(int &nVal1);

A. Func(a)

B. Func(&a)

C. Func(*a)

D. Func(&(*a))

正确答案:A

题解:

         我们观察函数,是引用,因此我们传参时,以一种类似 “传值” 的方式传参即可(底层是传指针,我们前面早已介绍过)

2、C++语言中,类ClassA的构造函数和析构函数的执行次数分别为()

ClassA *pclassa=new ClassA[5];
delete pclassa;

A. 5,1

B. 1,1

C. 5,5

D. 1,5

正确答案:A

题解:

         注意题目new一个对象时,用了 [ ] ,因此首先会创建5个classA对象的空间,然后再调用5次构造函数,而delete时,由于没有方括号因此只会调用一次析构函数,然后再所释放其空间,因此只调用一次析构;

3、动态内存分配(C语言中malloc,C++中的new)得到的存储区属于内存中的:

A. 静态区

B. 堆(heap)

C. 栈(stack)

D. 堆栈

E. 内核内存

F. 不确定

正确答案:B

题解:

        动态内存分配申请的空间来自于堆,概念题; 

4、下列静态数据成员的特性中,错误的是()

A. 引用静态数据成员时,要在静态数据成员名前加和作用域符号

B. 说明静态数据成员时前边要加关键字static来修饰

C. 静态数据成员在类体外进行初始化

D. 静态数据成员不是所有对象所共有的

正确答案:D

题解:

         静态成员变量属于这个类的所有对象,并不属于某个具体的对象;选D错误;

5、用class关键字定义的类,其成员默认的访问属性为()

A. private

B. protected

C. public

D. 无定义

正确答案:A

题解:

         class的成员默认访问权限为private,默认继承权限也为private,struct的成员默认访问权限为public,默认继承权限也为public;

6、在重载一个运算符为成员函数时,其参数表中没有任何参数,这说明该运算符是 ( )。

A. 无操作数的运算符

B. 二元运算符

C. 前缀一元运算符

D. 后缀一元运算符

正确答案:C

题解:

         当重载运算符为成员函数时,若其中没有任何参数,由于其是类的成员函数,故会传this指针,故应该为前缀一元运算符,若给参数int,则为后缀一元操作符;

7、有如下程序:运行时的输出结果是

#include<iostream>
using namespace std;
class MyClass
{
    public:
    MyClass(int i=0){cout<<1;}
    MyClass(const MyClass&x){cout<<2;}
    MyClass& operator=(const MyClass&x){cout<<3; return*this;}
    ~MyClass(){cout<<4;}
};
int main()
{
    MyClass obj1(1),obj2(2),obj3(obj1);
    return 0;
}

A. 121,444

B. 112,444

C. 11,114,444

D. 11,314,445

E. 11,314,444

正确答案:B

题解:

         分别创建3个对象,对象1和对象2使用的是构造函数,对象3是用拷贝构造进行初始化,因此会打印112,接着析构三个对象,打印444;

8、下面有关c++静态数据成员,说法正确的是()

A. 不能在类内初始化

B. 不能被类的对象调用

C. 不能受private修饰符的作用

D. 可以直接用类名调用

正确答案:D 

题解:

        A选项,对于普通静态数据成员,确实只能再类内声明,再类外进行定义,而const 修饰的静态整型家族数据成员,可以在类内定义,这是一种特殊语法;B选项,可以被类的对象调用;C选项,可以被private修饰;D选项,正确;

9、在C++中,为了让某个类只能通过new来创建(即如果直接创建对象,编译器将报错),应该()

A. 将构造函数设为私有

B. 将析构函数设为私有

C. 将构造函数和析构函数均设为私有

D. 没有办法能做到

正确答案:B

题解:

         假设我们将构造函数私有,由于构造函数私有,确实不能直接创建对象了,但是我们也不能通过new构造对象了,因此new主要分为两步,1、申请空间;2、调用构造进行初始化;,因此A错误;B选项,当我们将析构函数私有后,由于只能在类内调用析构,而我们一般创建的对象在出作用域时调用析构,由于无法调用析构,因此编译器也不允许我们直接构造对象,但由于构造并没有被封,我们可以通过new构造对象,然后如果我们需要析构这个对象,我们需要实现一个公有的方法,在这个公有的方法里调用析构,然后我们通过这个公有的方法进行析构;故B正确;

10、下列的模板声明中,其中几个是正确的()

1)template
2)template<T1,T2>
3)template<class T1,T2>
4)template<class T1,class T2>
5)template<typename T1,T2>
6)template<typename T1,typename T2>
7)template<class T1,typename T2>
8)<typename T1,class T2>

A. 2

B. 3

C. 4

D. 5

正确答案:B

题解:

         根据语法,每个类型参数前都必须由class或者typename,可以混用,故(4)(6)(7)都正确;选B;

四、编程题题解

1、另类加法

题解:我们利用异或的不进位加法特性进行解题,具体如下;

 

        我们得到了非进位的加法后的结果,那我们如何得到加法的进位呢?首先我们要清楚二进制的进位是两个二进制位都为1,相加后往后一位进1,你是否联想到了什么?我们是否可以通过两个数相与之后,在使用左移运算符,向左移动一位;这不就得到了我们的进位吗?

即 进位的数 = (A & B)<< 1;

 

        我们将进位的值与不进位相加的值进行相加不就是结果的值吗?(用或运算符)但是这个结果也是不准确的,因为我们要考虑连续进位的情况;因此有了以下代码;

class UnusualAdd 
{
public:
    int addAB(int A, int B) 
    {
        // 可能会出现连续进位的情况
        while(B)
        {
            int tmp = (A & B) << 1; // 进位的值
            A ^= B; // 不进位相加后的值
            B = tmp;
        }
        return A;
    }
};

2、走方格的方案数

题解:本题主要使用动态规划的思路进行解题,具体如下;

        有了以上的思路,具体我们还是来看代码是如何实现的;如下所示;

#include <iostream>
#include <vector>
using namespace std;

int main() 
{
    int n, m;
    cin >> n >> m;
    // 注意这里多开一个空间,因为题目给的是网格数
    vector<vector<int>> dp(n + 1, vector<int>(m + 1, 0));
    // 注意这里也必须都是小于等于
    for(int i = 0; i <= n; i++)
    {
        for(int j = 0; j <= m; j++)
        {
            if(i == 0 || j == 0)
            {
                dp[i][j] = 1;
            }
            else 
            {
                dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
            }
        }
    }
    cout << dp[n][m] << endl;
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值