一、编程语言
1.C++概念理解题
面试官:定义一个空的类型,里面没有任何成员变量和成员函数。对该类型求sizeof,得到的结果是多少?
应聘者:答案是1
面试官:为什么不是0?
应聘者:空类型的实例中不包含任何信息,本来求sizeof应该是0,但是当我们声明该类型的实例的时候,它必须在内存中占有一定的空间,否则无法使用这些实例.至于占用多少内存,由编译器决定。在VisuaI studio中,每个空类型的实例占用1字节的空间。
面试官:如果在该类型中添加一个构造函数和析构函数,再对该类型求sizeof,得到的结果又是多少?
应聘者:和前面一样,还是1。调用构造函数和析构函数只需要知道函数的地址即可,而这些函数的地址只与类型相关,而与类型的实例无关,编泽器也不会因为这两个函数而在实例内添加任何额外的信息。
面试官:那如果把析构函数标记为虚函数呢?
应聘者:C++的编译器一旦发现一个类型中有虚函数,就会为该类型生成虚函数表,并在该类型的每一个实例中添加一个指向虚函数表的指针。在32位的机器上,一个指针占4字节的空间,因此求sizeof得到4;如果是64位的机器,则一个指针占8字节的空间,因此求sizeof得到8。
2.代码分析题
代码如下,选项 A编译错误、B编译成功,运行崩溃、3编译运行正常,输出10 B
3.定义类或实现成员函数
重点考察构造函数、析构函数、运算符重载
二、数据结构
1.数组
占用连续的内存且按序存储,可以根据下标读写,所以时间效率高。
首先指定容量大小,预先分配内存,因此空间效率不是很好。(解决办法vector,扩容,但是有大量格外操作,影响时间性能)
2.字符串
C++中每个字符串都以‘\0’结尾,所以每个字符串都有一个额外字符的开销,容易越界。
3.链表
链表是一种动态数据结构,创建时无需知道链表长度,空间效率高
4.树
大部分考察二叉树,其中特例:二叉搜索树(O(logn))、堆(快速找到最大值、最小值)、红黑树(set、multiset、map、multimap等基本它实现)
5.栈和队列
栈:后进先出、不考虑排序
队列:先进先出
三、算法和数据操作
1.递归和循环
很多算法可以用递归和循环两种方式实现。基于递归的方法比较简洁,但是性能不如循环。
递归通常代码会很短,但是如果调用栈深度太大,会造成溢出。
2.查找和排序
排序和查找是算法的重点。顺序查找、二分查找、hash表查找、二叉排序数查找;插入排序、冒泡排序、归并排序、快速排序。
3.回溯法
如果要求在二维数组上搜索路径,尝试用回溯法,适合用递归实现,如果不可以用递归,呢么可以用栈来模拟递归。
4.动态规划与贪婪算法
如果求某问题的最优解,则可以分为多个子问题,动态规划、自上而下。也可能适用于贪婪算法。
5.位运算
特殊算法:位运算,把数字表示成二进制之后对0和1的操作。
位运算总共有5种运算:与、或、异或、左移、右移。如下图所示