剑指offer——第二章

一、编程语言

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种运算:与、或、异或、左移、右移。如下图所示

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值