《剑指Offer》读书笔记

LeetCode上的题目链接

https://leetcode-cn.com/problemset/lcof/

面试题1:赋值运算符函数

题目:给定一个类型(CMyString),为其添加赋值运算操作符函数。

注意以下四点

  • 返回值类型声明为该类型的引用,以便于连续赋值
  • 传入的参数类型为常量引用
  • 释放实例自身已有的内存,防止内存泄漏
  • 判断入参和当前实例(*this)是否同一个实例

面试题2:实现Singleton模式

面试题3:二维数组中的查找

思路是从右上角或左下角切入,每次剔除一行或一列,以加快查找速度。

面试题4:替换空格

先统计字符串长度和空格数,计算出变换后的字符串长度。然后从右往左逐字符变换。

面试题5:从尾到头打印链表

递归、非递归均可实现,递归版本简洁,非递归版本更健壮。

面试题6:重建二叉树

面试题7:用两个栈实现队列

面试题8:旋转数组的最小数字

面试题9:斐波那切数列

面试题10:二进制中1的个数

题目:请实现一个函数,输入一个整数,输出该数二进制表示中1的个数。

int NumberOf1(int n) {
    int count = 0;
    while (n) {
        count++;
        n = (n-1) & n; // 把一个整数减去1,再和原整数做与运算,会把该整数最右边一个1变成0.
    }
    return count;
}

面试题11:数值的整数次方

面试题12:打印1到最大的n位数

面试题13:在O(1)时间删除链表结点

面试题14:调整数组顺序使奇数位于偶数前面

面试题15:链表中的倒数第k个结点

面试题16:翻转链表

面试题17:合并两个排序的链表

面试题18:树的子结构

面试题19:二叉树的镜像

面试题20:顺时针打印矩阵

面试题21:包含min函数的栈

面试题22:栈的压入、弹出序列

面试题23:从上往下打印二叉树

面试题24:二叉搜索树的后序遍历序列

面试题25:二叉树中和为某一值的路径

面试题26:复杂链表的复制

面试题27:二叉搜索树与双向链表

面试题28:字符串的排列

面试题29:数组中出现次数超过一半的数字

面试题30:最小的k个数

面试题31:连续子数组的最大和

面试题32:从1到n整数中1出现的次数

面试题33:把数组排成最小的数

面试题34:丑数

面试题35:第一个只出现一次的字符

面试题36:数组中的逆序对

面试题37:两个链表的第一个公共结点

面试题38:数字在排序数组中出现的次数

面试题39:二叉树的深度

面试题40:数组中只出现一次的数字

面试题41:和为s的两个数字 vs. 和为s的连续正数序列

面试题42:翻转单词顺序 vs. 左旋转字符串

面试题43:n个骰子的点数

面试题44:扑克牌的顺子

面试题45:圆圈中最后剩下的数字

面试题46:求1+2+...+n

面试题47:不用加减乘除做加法

面试题48:不能被集成的类

面试题49:把字符串转换成数字

面试题50:树中两个结点的最低公共祖先

面试题51:数组中重复的数字

面试题52:构建乘积数组

面试题53:正则表达式匹配

面试题54:标识数组的字符串

面试题55:字符流中第一个不重复的字符

面试题56:链表中环的入口结点

面试题57:删除链表中重复的结点

面试题58:二叉树的下一个结点

面试题59:对称的二叉树

面试题60:把二叉树打印成多行

面试题61:按之字形顺序打印二叉树

面试题62:序列化二叉树

面试题63:二叉搜索树的第k个结点

面试题64:数据流中的中位数

面试题65:滑动窗口的最大值

面试题66:矩阵中的路径

面试题67:机器人的运动范围

拾遗

1. 关于“为什么跳槽”

总体上可以大胆地根据自己的真实想法来回答这个问题。但是切记不要抱怨、不要流露出负面的情绪。

2. 为什么复制构造函数必须传入引用类型

如果允许复制构造函数传值,就会在复制构造函数内调用复制构造函数,就会形成永无休止的递归调用从而导致栈溢出。

因此C++标准不允许复制构造函数传值参数,在Visual Studio和GCC中,都会导致编译出错。

3. 语言面试的3种类型

  • 直接询问应聘者对C++概念的理解,如常见的关键字等。
    • 4个类型转换的关键字,特点与应用场合
    • sizeof操作符
  • 拿出事先准备好的代码,让应聘者分析代码的运行结果。
  • 要求应聘者写代码定义一个类型或者实现类型中的成员函数。

4. 解决复杂问题的一个有效方法

从一个具体的问题入手,通过分析简单具体的例子,试图寻找普遍的规律。

5. 修改输入数据

面试题中,如果打算修改输入的数据,最好先问面试官是不是允许做修改。

posted @ 2020-05-05 14:54  不写诗的诗人小安  阅读(139)  评论(0编辑  收藏  举报