【C++笔试强训】第八天_以下正确的重载函数是( )。aint same (int, double); double same(1)

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip204888 (备注大数据)
img

正文

A 用一个对象去初始化同一个类的另一个新对象时
B 将类的一个对象赋值给该类的另一个对象时
C 函数的形参对象,调用函数进行形参和实参结合时
D 函数的返回值是类的对象,函数执行返回调用时

这道题需要对拷贝构造了解才可以解题,理解其概念

请添加图片描述

A 就是场景1
B 赋值调用的不是拷贝构造,调用的是赋值运算符重载
C 这种情况会讲实参拷贝构造一份给给形参
D 就是场景3

这道题的答案是B


💦第六题

以下代码共调用多少次拷贝构造函数:

Widget f(Widget u)
{
	Widget v(u);
	Widget w=v;
	return w;
}
main(){
	Widget x;
	Widget y=f(f(x));
}

A 1
B 3
C 5
D 7

这道题有一定的难度,我们上一道题已经了解了构造场景,我们这道题来验证一下

y对象的构造将来也需要调用构造函数

f(x)在传参数会调用一次,用v(u)拷贝一次,用v构造w又一次,返回需要借助w调用临时对象,所以又有一次,结束之后需要利用临时对象再次进入f(x)中进行调用,这里也有4次,最后用返回值构造y,一共有9次

注意:按照我们刚刚的算法没有任何问题,但是当函数返回值是类类型对象时,编译器可能会对返回值的类型进行优化

在返回值的时候我们需要创建临时对象,编译器可能会直接拿着临时对象使用,这样子可以少调用一次

这道题的答案是D


💦第七题

如果友元函数重载一个运算符时,其参数表中没有任何参数则说明该运算符是()

A 一元运算符
B 二元运算符
C 选项A)和选项B)都可能
D 重载错误

这道题需要知道什么时候需要运算符重载

请添加图片描述

如果重载成友元函数,但没有任何参数,所以错误,必须要有一个参数是类类型的对象

这道题的答案是D


💦第八题

class A;
class B;
int main() {
	A a;
	B b;
	return 0;
}

在 main 函数中,变量 a 和 b 的构造函数和析构函数的调用顺序是()

A b构造 - a构造 - a析构 - b析构
B a构造 - a析构 - b构造 - b析构
C b构造 - a构造 - b析构 - a析构
D a构造 - b构造 - b析构 - a析构

F 函数先构造a 再构造b,析构是在栈上的,所以后构造的先析构

这道题的答案是D


💦第九题

下面 C++ 程序的运行结果为()

#include <iostream>
using namespace std;
class cla {
	static int n;
public:
	cla() { n++; }
	~cla() { n--; }
	static int get\_n() { return n; }
};

int cla::n = 0;

int main() {
	cla\* p = new cla;
	delete p;
	cout << "n=" << cla::get\_n() << endl;
	return 0;
}

A n=3
B n=4
C n=1
D n=0

在cla中定了类静态类型的对象,所以是所有类共享的,将n初始为0,然后构造n++,之后析构n–

在main函数中,先构造,然后n = 1,然后析构,n = 0,然后打印,所以n的值并不会变

这道题的答案是D


💦第十题

运行的程序总要与内存进行交互。内存作为操作系统中的重要资源,对内存的分配和释放进行管理是一项非常重要的工作,以下说法中错误的是 ______。

A 内存泄露是内存管理中的常见问题
B 悬挂引用指的是对某个对象的应用实际上指向一个错误的内存地址
C 在C、C++等系统语言中,有自动的内存管理机制,不需要考虑内存管理的问题
D 程序的动态性越强,内存管理就越重要,内存分配程序的选择也就更重要

C/C++没有内存回收机制,所有在堆上申请的内存都需要用户手动释放

A 因为没有内存回收机制,所以内存泄漏这个问题需要用户处理

B 我们用个Swap来进行举例,看起来是用整型变量,实际上是使用地址

请添加图片描述

C 没有内存回收机制,需要考虑内存管理问题

D 程序的动态性越强,内存管理就越重要,内存分配程序的选择也就更重要

这道题的答案是C


编程题

🔥第一题

链接:两种排序方法

请添加图片描述

  • 解题思路

思路很简单,将接受的字符串都放到vector容器中,利用string的operator>=运算符重载来按ascii比较字符串,利用string的size来比较字符串的长度

  • 代码演示
#include <iostream>
#include <vector>
#include <string>
using namespace std;

int main() 
{
    vector<string> v;
    int n;
    cin >> n;
    v.resize(n);
    for(auto &str : v)
    {
        cin >> str;
    }
    bool lsort = true, csort = true;
    
    for(int i = 0;i < n;i++)
    {
        if(v[i - 1].size() > v[i].size())
        {
            lsort = false;//并非按长度排序
            break;
        }
    }

    for(int i = 1 ; i< n;i++)
    {
        if(v[i - 1] > v[i])
        {
            csort = false;//并非按字典排序
            break;
        }
    }
	
	//判断是哪种情况
    if(lsort && csort)
        cout << "both" << endl;
    else if(lsort)
        cout << "lengths" << endl;
    else if(csort)
        cout << "lexicographically" << endl;
    else
        cout << "none" << endl;
    return 0;
}


🔥第二题

链接:求最小公倍数

请添加图片描述

  • 解题思路

最小公倍数 = 两数之积除以最大公约数,这里使用碾转相除法进行最大公约数的求解:即a与b的最大公约数可以转化为a、b之间的余数为两者之间最小的数之间的公约数。所以对于输入的两个数进行连续求余,直到余数为0,求余的分母即为结果。

  • 代码演示
#include <iostream>
using namespace std;

// 方法一:暴力破解,用最大的数枚举得到最小公倍数

// int main() {
// int A, B;
// while (cin >> A >> B) {
// int m = max(A, B);
// while (1) {
// if (m % A == 0 && m % B == 0) {
// cout << m << endl;
// break;
// }
// m++;
// }
// }

// return 0;
// }

// 方法二: 更优解法,数学公式:两个数的最小公倍数就是两个数的乘积 / 最小公约数


**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注大数据)**
![img](https://img-blog.csdnimg.cn/img_convert/a8b7bec77815195e3965b0c2c340d4e3.png)

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

 % B == 0) {
// cout << m << endl;
// break;
// }
// m++;
// }
// }

// return 0;
// }

// 方法二: 更优解法,数学公式:两个数的最小公倍数就是两个数的乘积 / 最小公约数


**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注大数据)**
[外链图片转存中...(img-udXxWoEE-1713339249657)]

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值