剑指offer刷题心得(技术准备篇1)

1 《编程语言》

>
1. C++ 准备
- 《Effective C++》适合面试之前突击,罗列了常用问题以及解决方案;
- 《C++ Primer》全面了解,不露死角;
- 《Inside C++ Object Model》深入了解C++对象内部,如对象sizeof, 虚函数调用机制;
- 《The C++ Programming Language》全面深入了解C++.
2. 多维度考察基本功
- 以复制运算符函数为例:
- 返回值是否为该类型的引用;
- 是否传入参数的类型声明为常量引用;
- 是否判传入的参数和当前的实例(*this)是不是同一个实例,如果是同一个是不能直接进行赋值操作,应该直接返回;
- 是否考虑异常安全:赋值运算符函数内部抛出异常,不能破坏原本实例的状态;

2《数据结构》

链表和树是面试中出现频率最高的数据结构,由于操作链表和指针需要大量的指针,代码鲁棒性是需要特别注意的,否则容易出现程序崩溃的问题。栈是一个与递归密切相关的数据结构,队列也与广度优先遍历算法紧密相关。
a. 数组:占据一块连续的内存并按照顺序存储数据。创建数组时,要首先制定数组的容量大小,然后根据容量大小分配内存。即使只在数组中存储一个数字,也需要为所有数据预先分配内存。连续性可以根据下标在O(1)时间去读/写,因此效率非常高,也可以实现简单的哈希表。动态数组如C++ STL中的vector,
b, 字符串:C/C++的字符串以’\0‘作为结尾。为了节省内存,C/C++把常量字符串放到单独的一个内存区域。当几个指针赋值给相同的常量字符串时,他们实际上指向相同的内存地址,但用常量字符串初始化数组时,情况却不一样,会重新分配地址,类似copy。
c. 链表:《未完待续。。。》

《算例分析》

/*<Case 1: Check the result of the program after running>
//Analyze the result of below code
class A
{
    private:
    {
        int value;
    }
    public:
    {
        A(int n){ value = n
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值